前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Redis命令详解:Transactions

Redis命令详解:Transactions

作者头像
Jackeyzhe
发布2020-03-11 12:42:44
3270
发布2020-03-11 12:42:44
举报

Redis的事务和我们常见的数据库的事务最大的区别就是,Redis的事务中如果有一个命令执行失败,其他命令仍然可以执行成功。Redis的事务以MULTI开始,由EXEC触发。在EXEC前的操作都将被放入缓存队列中。在事务执行过程中其他客户端的命令不会插到事务中执行。下面就来介绍一下Redis事务相关的命令。

DISCARD

最早可用版本:2.0.0

放弃所有队列中的命令,将连接状态置为正常状态。如果事务被WATCH,则取消所有的WATCH。

EXEC

最早可用版本:1.2.0

执行队列中的全部命令,将连接状态置为正常状态。如果某些key处于被监视状态,并且队列中有和这些key相关的命令。那么EXEC命令只有在这些key的值没有变化的情况下事务才会执行,否则事务被打断。

MULTI

最早可用版本:1.2.0

标记事务块的开始,之后的命令被顺序插入缓存队列中,可以用EXEC命令执行这些命令。

UNWATCH

最早可用版本:2.2.0

时间复杂度:O(1)

清除掉所有被WATCH的key,如果调用了EXEC或者DISCARD命令,则不用手动调用UNWATCH命令。

WATCH

最早可用版本:2.2.0

时间复杂度:对每个都是O(1)

将指定的key标记为被监视状态,如果事务执行前被改动,则事务会被打断。

最后举一个事务被打断的栗子

127.0.0.1:6379> SET lock_time 1
OK
127.0.0.1:6379> WATCH lock_time
OK
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET transcation_key z #这时另一个客户端执行了命令 SET lock_time 2
QUEUED
127.0.0.1:6379> INCR lock_time
QUEUED
127.0.0.1:6379> EXEC
(nil)
127.0.0.1:6379> GET transcation_key
(nil)

看都看完了,还不点这里试试

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2019-03-06,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 代码洁癖患者 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • DISCARD
  • EXEC
  • MULTI
  • UNWATCH
  • WATCH
相关产品与服务
云数据库 Redis
腾讯云数据库 Redis(TencentDB for Redis)是腾讯云打造的兼容 Redis 协议的缓存和存储服务。丰富的数据结构能帮助您完成不同类型的业务场景开发。支持主从热备,提供自动容灾切换、数据备份、故障迁移、实例监控、在线扩容、数据回档等全套的数据库服务。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档