原子性:要么同时成功,要么同时失败!
区别:Redis单条命令是保证原子性的,但是事务不保证原子性的!
Redis事务的本质:一组命令的集合!一个事务中的所有命令都会被序列化!会按照顺序执行!
一次性、顺序性、排他性!执行一系列的命令!
Redis事务没有隔离级别的概念!(没有幻读、脏读)
也就是在入队的时候是不会被执行的!只有发起命令时,才会被执行!
Redis事务:
1、开启事务()
2、命令入队()
3、执行事务()
正常执行事务
127.0.0.1:6379[1]> multi ##开启事务
OK
127.0.0.1:6379[1]> set key1 v1 ##命令入队(并没有执行)
QUEUED
127.0.0.1:6379[1]> set key2 v2
QUEUED
127.0.0.1:6379[1]> set key3 v3
QUEUED
127.0.0.1:6379[1]> exec ##执行事务
1) OK ##最终结果
2) OK
3) OK
放弃事务
127.0.0.1:6379[1]> multi ##开启事务
OK
127.0.0.1:6379[1]> set k1 v1 ##命令入队
QUEUED
127.0.0.1:6379[1]> set k2 v2
QUEUED
127.0.0.1:6379[1]> set k3 v3
QUEUED
127.0.0.1:6379[1]> discard ##取消事务(事务将不会执行)
OK
127.0.0.1:6379[1]> get k1 ##数据测试(事务队列中的命令都不会被执行)
(nil)
代码错误
1、编译型异常(代码有问题!命令有错) 事务中的命令都不会被执行
127.0.0.1:6379[1]> multi ##开启事务
OK
127.0.0.1:6379[1]> set k1 v1 ##命令入队
QUEUED
127.0.0.1:6379[1]> set k2 v2
QUEUED
127.0.0.1:6379[1]> getset k3 v3 ##代码错误
QUEUED
127.0.0.1:6379[1]> setget k4 v4
(error) ERR unknown command 'setget'
127.0.0.1:6379[1]> exec ##事务执行失败
(error) EXECABORT Transaction discarded because of previous errors.
2、运行时异常
127.0.0.1:6379[1]> set k1 "v1"
OK
127.0.0.1:6379[1]> multi ##开启事务
OK
127.0.0.1:6379[1]> incr k1 ##执行加一
QUEUED
127.0.0.1:6379[1]> set k2 v2 ##命令入队
QUEUED
127.0.0.1:6379[1]> set k3 v3
QUEUED
127.0.0.1:6379[1]> exec ##执行事务
1) (error) ERR value is not an integer or out of range ##运行时异常不会结束所有事务
2) OK
3) OK