命令:exec
测试:
127.0.0.1:6379> set wang 200
OK
127.0.0.1:6379> set zhao 300
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decrby zhao 100
QUEUED
127.0.0.1:6379> incrby wang 100
QUEUED
127.0.0.1:6379> get wang
QUEUED
127.0.0.1:6379> get zhao
QUEUED
127.0.0.1:6379> exec
1) (integer) 200
2) (integer) 300
3) "300"
4) "200"
11.3 取消事务
命令:discard
测试:
127.0.0.1:6379> mget wang zhao
1) "400"
2) "100"
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decrby wang 100
QUEUED
127.0.0.1:6379> incrby zhao 100
QUEUED
127.0.0.1:6379> discard
OK
127.0.0.1:6379> mget wang zhao
1) "400"
2) "100"
11.4 注意
① 在事务执行过程中,有语法错误,则所有的语句均不能执行
② 在事务执行过程中,语法本身没有问题,但是适用对象出现问题,则部分不能执行
11.5 锁机制(乐观锁)
11.5.1 不使用锁出现的现象
模拟买票的一个场景,票只剩1张:
127.0.0.1:6379> set ticket 1
OK
127.0.0.1:6379> set wang 300
OK
127.0.0.1:6379> mget ticket wang
1) "1"
2) "300"
首先,A用户执行以下语句:
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decr ticket
QUEUED
127.0.0.1:6379> decrby wang 100
QUEUED
然后,B用户执行以下语句:
127.0.0.1:6379> decr ticket
(integer) 0
最后,A用户提交事务:
127.0.0.1:6379> exec
1) (integer) -1
2) (integer) 200
由上可以看出,票变为了-1,钱减少了。但是这种情况是不允许发生的。因此,需要锁机制来进行控制。
11.5.2 使用锁机制进行控制
模拟买票的一个场景,票只剩1张:
127.0.0.1:6379> set ticket 1
OK
127.0.0.1:6379> set wang 300
OK
127.0.0.1:6379> mget ticket wang
1) "1"
2) "300"
首先,A用户执行以下语句:
127.0.0.1:6379> watch ticket
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379> decr ticket
QUEUED
127.0.0.1:6379> decrby wang 100
QUEUED
然后,B用户执行以下语句:
127.0.0.1:6379> decr ticket
最后,A用户提交事务:
127.0.0.1:6379> exec
(nil)
查看结果:
127.0.0.1:6379> mget ticket wang
1) "0"
2) "300"
已经解决了上述问题。
11、redis事务以及锁机制11.1 事务的开启 命令:multi11.2 事务的提交 命令:exec 测试: 127.0.0.1:6379> set wang 200 OK 127.0.0.1:6379> set zhao 300 OK 127.0.0.1:6379> multi OK 127.0.0.1:6379>