redis的事务不具有原子性,在事务中,多条命令执行时,若是其中一条或者多条命令执行失败,并不会影响其余命令的执行,以前执行成功的命令也不会回滚,而以后还没有执行的命令将会继续执行。redis
命令格式:code
- `MULTI`:开始事务 - `command`:命令入队 - `EXEC`:执行
127.0.0.1:6379> MULTI OK 127.0.0.1:6379> SET name j QUEUED 127.0.0.1:6379> SET age 11 QUEUED 127.0.0.1:6379> EXEC 1) OK 2) OK 127.0.0.1:6379> GET name "j" 127.0.0.1:6379> get age "11"
命令格式:事务
- `MULTI`:开始事务 - `command`:命令入队 - `DISCARD`:取消事务
127.0.0.1:6379> MULTI OK 127.0.0.1:6379> SET num 100 QUEUED 127.0.0.1:6379> DISCARD OK 127.0.0.1:6379> GET num (nil)
# 先放入一个String 127.0.0.1:6379> SET name lyxxxx OK # 此时重新设置`name`为`hash`将会报错,由于类型不匹配 127.0.0.1:6379> hset name first lin (error) WRONGTYPE Operation against a key holding the wrong kind of value # 此时开始事务 127.0.0.1:6379> MULTI OK 127.0.0.1:6379> set age 25 QUEUED 127.0.0.1:6379> set name first l QUEUED 127.0.0.1:6379> set sex male QUEUED 127.0.0.1:6379> EXEC 1) OK 2) (error) ERR syntax error 3) OK # 从上面的(2)能够看出`set name first l`执行失败了,可是(3)仍是成功了 127.0.0.1:6379> get sex "male"
key
改变,取消事务命令格式:get
- `WATCH key [key key ...]`:监听`key` - `UNWATCH`:取消监听
监听name
:hash
127.0.0.1:6379> watch name OK
把name
改变io
127.0.0.1:6379> set name lyxxx2 OK
执行事务,由于name
已经被改变了事务执行失败了,返回nil
,而且值未被改变command
127.0.0.1:6379> MULTI OK 127.0.0.1:6379> set name lxxxx3 QUEUED # name 已经被改变了,因此事务执行失败了 127.0.0.1:6379> EXEC (nil) 127.0.0.1:6379> get name "lyxxx2"
取消监听并再次执行事务,此时事务将会成功error
127.0.0.1:6379> UNWATCH OK 127.0.0.1:6379> MULTI OK 127.0.0.1:6379> set name lxxxx3 QUEUED 127.0.0.1:6379> EXEC 1) OK 127.0.0.1:6379> GET name "lxxxx2"