Redis 事务 命令
2024-01-09 10:02:48
目录
1.Redis Exec 命令 - 执行所有事务块内的命令。
简介
Redis Exec 命令用于执行所有事务块内的命令。Redis 事务
语法
redis 127.0.0.1:6379> Exec
可用版本: >= 1.2.0
返回值: 事务块内所有命令的返回值,按命令执行的先后顺序排列。 当操作被打断时,返回空值 nil 。
示例
# 事务被成功执行
redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> INCR user_id
QUEUED
redis 127.0.0.1:6379> INCR user_id
QUEUED
redis 127.0.0.1:6379> INCR user_id
QUEUED
redis 127.0.0.1:6379> PING
QUEUED
redis 127.0.0.1:6379> EXEC
1) (integer) 1
2) (integer) 2
3) (integer) 3
4) PONG
# 监视 key ,且事务成功执行
redis 127.0.0.1:6379> WATCH lock lock_times
OK
redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> SET lock "huangz"
QUEUED
redis 127.0.0.1:6379> INCR lock_times
QUEUED
redis 127.0.0.1:6379> EXEC
1) OK
2) (integer) 1
# 监视 key ,且事务被打断
redis 127.0.0.1:6379> WATCH lock lock_times
OK
redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> SET lock "joe" # 就在这时,另一个客户端修改了 lock_times 的值
QUEUED
redis 127.0.0.1:6379> INCR lock_times
QUEUED
redis 127.0.0.1:6379> EXEC # 因为 lock_times 被修改, joe 的事务执行失败
(nil)
2.Redis Watch 命令 - 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
简介
Redis Watch 命令用于监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断Redis 事务
语法
redis 127.0.0.1:6379> Watch
可用版本: >= 2.2.0
返回值: 总是返回 OK 。
示例
redis> WATCH lock lock_times
OK
3.Redis Discard 命令 - 取消事务,放弃执行事务块内的所有命令。
简介
Redis Discard 命令用于取消事务,放弃执行事务块内的所有命令。Redis 事务
语法
redis 127.0.0.1:6379> DISCARD
可用版本: >= 2.0.0
返回值: 总是返回 OK 。
示例
redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> PING
QUEUED
redis 127.0.0.1:6379> SET greeting "hello"
QUEUED
redis 127.0.0.1:6379> DISCARD
OK
4.Redis Unwatch 命令 - 取消 WATCH 命令对所有 key 的监视。
简介
Redis Unwatch 命令用于取消 WATCH 命令对所有 key 的监视。Redis 事务
语法
redis 127.0.0.1:6379> UNWATCH
可用版本: >= 2.2.0
返回值: 总是返回 OK 。
示例
redis 127.0.0.1:6379> WATCH lock lock_times
OK
redis 127.0.0.1:6379> UNWATCH
OK
5.Redis Multi 命令 - 标记一个事务块的开始。
简介
事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令原子性(atomic)地执行。Redis Multi 命令用于标记一个事务块的开始。Redis 事务
语法
redis 127.0.0.1:6379> Multi
可用版本: >= 1.2.0
返回值: 总是返回 OK 。
示例
redis 127.0.0.1:6379> MULTI # 标记事务开始
OK
redis 127.0.0.1:6379> INCR user_id # 多条命令按顺序入队
QUEUED
redis 127.0.0.1:6379> INCR user_id
QUEUED
redis 127.0.0.1:6379> INCR user_id
QUEUED
redis 127.0.0.1:6379> PING
QUEUED
redis 127.0.0.1:6379> EXEC # 执行
1) (integer) 1
2) (integer) 2
3) (integer) 3
4) PONG
总结
文章来源:https://blog.csdn.net/gzu_01/article/details/135470981
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!