redis事务

redis 事务

redis 事务的本质:一组命令的集合!一个事务中的所有命令都会被序列化,在事务执行过程中,会按照顺序执行!一次性,顺序性,排他性!

  • redis 事务没有隔离级别的概念
  • 所有的命令在事务中,并没有直接被执行!只有发起执行命令(exec)的时候才会执行
  • redis 单条命令是保证原子性的,但是事务不保证原子性
常用命令
命令说明
multi开启事务
exec执行事务
discard取消事务,事务队列中所有命令都不会执行
redis 事务异常
  • 编译型异常,代码或命令有错误,队列中所有命令都不会执行
  • 执行时异常,代码正确,运行错误(如 1/0 错误),只出错命令不执行,其他命令正常执行
示例
## 正常执行事务
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set key1 value1
QUEUED
127.0.0.1:6379> set key2 value2
QUEUED
127.0.0.1:6379> get key1
QUEUED
127.0.0.1:6379> set key3 value3
QUEUED
127.0.0.1:6379> exec
1) OK
2) OK
3) "value1"
4) OK
127.0.0.1:6379> get key3
"value3"

## 取消事务
127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set key1 value1
QUEUED
127.0.0.1:6379> set key2 value2
QUEUED
127.0.0.1:6379> discard
OK
127.0.0.1:6379> get key1
(nil)
127.0.0.1:6379> get key2
(nil)

## 编译型异常
127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set key1 value1
QUEUED
127.0.0.1:6379> settttt key2 value2
(error) ERR unknown command 'settttt'
127.0.0.1:6379> exec
(error) EXECABORT Transaction discarded because of previous errors.
127.0.0.1:6379> get key1
(nil)
127.0.0.1:6379> get key2
(nil)

## 执行时异常
127.0.0.1:6379> flushdb
OK
127.0.0.1:6379> set mykey hello
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> set key1 value1
QUEUED
127.0.0.1:6379> incr mykey
QUEUED
127.0.0.1:6379> set key2 value2
QUEUED
127.0.0.1:6379> exec
1) OK
2) (error) ERR value is not an integer or out of range     ## mykey为String类型,不能自增,执行出错,其他命令执行正常
3) OK
127.0.0.1:6379> get mykey
"hello"
127.0.0.1:6379> get key1
"value1"
127.0.0.1:6379> get key2
"value2"


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值