1. 事务是什么?
这里给出百度百科的解释:事务(Transaction),一般是指要做的或所做的事情。在计算机术语中是指访问并可能更新数据库中各种数据项的一个程序执行单元(unit)。事务通常由高级数据库操纵语言或编程语言(如SQL,C++或Java)书写的用户程序的执行所引起,并用形如begin transaction和end transaction语句(或函数调用)来界定。事务由事务开始(begin transaction)和事务结束(end transaction)之间执行的全体操作组成。
用mysql数据库的事务来说就是:事务可以是一条sql(或指令) 或 一连串sql(或指令)组成的程序
2. redis事务
redis中事务的概念就是一次执行多条命令;并带有以下三个保证:
- 批量操作在发送 EXEC 命令前被放入队列缓存。
- 收到 EXEC 命令后进入事务执行,事务中任意命令执行失败,其余的命令依然被执行。
- 在事务执行过程,其他客户端提交的命令请求不会插入到事务执行命令序列中。
一个redis事务会经过三个步骤:开始事务 - 》命令入队 - 》执行事务
注意
- redis是不支持事务回滚的操作,看上面加粗的文字;
- 单个redis命令是原子性的,但是多个redis事务是多个命令一起执行的时候是不具备原子性的;
3. mysql 事务
mysql中innodb引擎支持事务,与redis事务不同在于,mysql事务的特性是ACID(原子性、一致性、持久性、隔离性),而redis只支持持久性、隔离性;
5. redis事务应用场景?
需要批量执行redis命令的;