事务
回顾
我们在MySQL中学习的事务具有ACID原则
原子性(Atomicity)
原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
一致性(Consistency)
事务前后数据的完整性必须保持一致。
隔离性(Isolation)
事务的隔离性是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。
持久性(Durability)
持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响
Redis中的事务
事务的本质即:一组命令一起执行,不允许被插队。
在Redis中,单条命令是原子性的,但是事务不保证原子性
事务没有隔离级别的概念
1 | # 开启事务 |
编译时异常:即代码本身又问退,比如
127.0.0.1:6379> asdmlk (error) ERR unknown command 'asdmlk'
命令行会直接报错
1 | 127.0.0.1:6379> multi |
可以发现所有的命令都没有执行。
运行时异常:如果事务队列中存在这种错误,其他语句照常执行,该语句不执行,抛出异常
1 | 127.0.0.1:6379> set k1 var |