Redis中的事务操作

原子性:要么同时成功,要么同时失败!

区别: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
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。