redis事务
- DISCARD
取消事务,放弃执行事务块内的所有命令。 - EXEC
执行所有事务块内的命令。 - MULTI
标记一个事务块的开始。 - UNWATCH
取消 WATCH 命令对所有 key 的监视。 - WATCH key [key …]
监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
字符串键值对
set 键 值
键为name,值为zhangsan
set name zhangsan
redis 127.0.0.1:6379> set name zhangsan
OK
根据键查看值
get name
redis 127.0.0.1:6379> get name
"zhangsan"
l–>left,左插法
lpush 队列名 值
r–>right,右插法
rpush 队列名 值
取值,开始为0,结束为-1表示最后一个元素。
lrange 队列名 开始索引 结束索引
redis 127.0.0.1:6379> lpush lines lisi
(integer) 1
redis 127.0.0.1:6379> lpush lines wangwu
(integer) 2
redis 127.0.0.1:6379> lpush lines zhaoliu
(integer) 3
redis 127.0.0.1:6379> lrange lines
(error) ERR wrong number of arguments for 'lrange' command
redis 127.0.0.1:6379> lrange lines 0 -1
1) "zhaoliu"
2) "wangwu"
3) "lisi"
redis 127.0.0.1:6379>
multi
开启事务之后,
如果里面输入一个lrange name
直接出现语法错误这种的,最后提交exec
的时候是不成功的。
redis 127.0.0.1:6379> multi
OK
redis 127.0.0.1:6379> set name zhangsan
QUEUED
redis 127.0.0.1:6379> lrange name
(error) ERR wrong number of arguments for 'lrange' command
redis 127.0.0.1:6379> set age 20
QUEUED
redis 127.0.0.1:6379> exec
(error) EXECABORT Transaction discarded because of previous errors.
redis 127.0.0.1:6379> keys *
(empty list or set)
但是如果lrange name 0 -1
语法正确的,但是没有name
这个队列的话,最后是,能执行成功的就执行成功,执行不成功的就不成功。
注意:此时和关系型数据库的事务是不一样的,关系型数据库事务,要么同时成功,要么同时失败。不能只执行其中的一部分。
单个 Redis 命令的执行是原子性的,但 Redis 没有在事务上增加任何维持原子性的机制,所以 Redis 事务的执行并不是原子性的。
事务可以理解为一个打包的批量执行脚本,但批量指令并非原子化的操作,中间某条指令的失败不会导致前面已做指令的回滚,也不会造成后续的指令不做。
这是官网上的说明 From redis docs on transactions:
It’s important to note that even when a command fails, all the other commands in the queue are processed – Redis will not stop the processing of commands.
例如:
redis 127.0.0.1:6379> multi
OK
redis 127.0.0.1:6379> set name zhangsan
QUEUED
redis 127.0.0.1:6379> lrange name 0 -1
QUEUED
redis 127.0.0.1:6379> set age 20
QUEUED
redis 127.0.0.1:6379> exec
1) OK
2) (error) ERR Operation against a key holding the wrong kind of value
3) OK
redis 127.0.0.1:6379> keys *
1) "age"
2) "name"
redis 127.0.0.1:6379>