当前位置: 首页 > news >正文

Redis事务

2019独角兽企业重金招聘Python工程师标准>>> hot3.png

事务相关命令

MULTI

自1.2.0可用。

**时间复杂度:**O(1)。

语法:MULTI
说明:

标记一个事务块的开始。

事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令原子性(atomic)地执行。

返回值:

总是返回 OK

示例:
# 下面命令在 客户端1 中执行
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET testMULTI 0
QUEUED
127.0.0.1:6379> INCR testMULTI
QUEUED
127.0.0.1:6379> INCR testMULTI
QUEUED
127.0.0.1:6379> INCR testMULTI
QUEUED

# 这个时候从另一个 客户端(我们称呼为客户端2) 执行以下:
127.0.0.1:6379> GET testMULTI
(nil)
# 此时我们可以看到 客户端1 的命令还没有执行
# 下面切换到 客户端1 执行 EXEC
127.0.0.1:6379> EXEC
1) OK
2) (integer) 1
3) (integer) 2
4) (integer) 3
# 此时在 客户端2 中就可以访问到 该数据了
127.0.0.1:6379> GET testMULTI
"3"

DISCARD

自2.0.0可用。

**时间复杂度:**O(1)。

语法:DISCARD
说明:

取消事务,放弃执行事务块内的所有命令。

如果正在使用 WATCH 命令监视某个(或某些) key,那么取消所有监视,等同于执行命令 UNWATCH

返回值:

总是返回 OK

示例:
# 当没有事务开启时
127.0.0.1:6379> DISCARD
(error) ERR DISCARD without MULTI

127.0.0.1:6379> MULTI
OK
# ping 用来查询状态 测试该客户端处于队列状态(开启事务时命令只是装入队列并不会执行)
127.0.0.1:6379> PING
QUEUED
127.0.0.1:6379> SET testDISCARD
(error) ERR wrong number of arguments for 'set' command
127.0.0.1:6379> SET testDISCARD a
QUEUED
# 退出事务
127.0.0.1:6379> DISCARD
OK
# 状态恢复正常状态
127.0.0.1:6379> PING
PONG
# 事务中的命令没有执行
127.0.0.1:6379> GET testDISCARD
(nil)

WATCH

自2.2.0可用。

**时间复杂度:**O(1)。

语法:WATCH key [key ...]
说明:

监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。

返回值:

总是返回 OK

示例:

在之后的 EXEC 命令中会详细介绍。

UNWATCH

自2.2.0可用。

**时间复杂度:**O(1)。

语法:UNWATCH
说明:

取消 WATCH 命令对所有 key 的监视。

如果在执行 WATCH 命令之后, EXEC 命令或 DISCARD 命令先被执行了的话,那么就不需要再执行 UNWATCH 了。

因为 EXEC 命令会执行事务,因此 WATCH 命令的效果已经产生了;而 DISCARD 命令在取消事务的同时也会取消所有对 key 的监视,因此这两个命令执行之后,就没有必要执行 UNWATCH 了。

返回值:

总是返回 OK

示例:

在之后的 EXEC 命令中会详细介绍。

EXEC

自1.2.0可用。

**时间复杂度:**事务块内所有命令的时间复杂度的总和。

语法:DISCARD
说明:

执行所有事务块内的命令。

假如某个(或某些) key 正处于 WATCH 命令的监视之下,且事务块中有和这个(或这些) key 相关的命令,那么 EXEC 命令只在这个(或这些) key 没有被其他命令所改动的情况下执行并生效,否则该事务被打断(abort)。

返回值:

事务块内所有命令的返回值,按命令执行的先后顺序排列。

当操作被打断时,返回空值 nil

示例:
# 在 MULTI 命令的实例中我们演示了事务正常执行的情况
# 客户端1
# 使用 WATCH 监视 key 且正常执行成功
127.0.0.1:6379> WATCH testWATCH
OK
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET testWATCH 2123
QUEUED
127.0.0.1:6379> EXEC
1) OK
# 使用 WATCH 监视 key 且未正常执行
127.0.0.1:6379> WATCH testWATCH
OK
127.0.0.1:6379> SET testWATCH a
OK
127.0.0.1:6379> GET test WATCH
(error) ERR wrong number of arguments for 'get' command
127.0.0.1:6379> GET testWATCH
"a"
127.0.0.1:6379> DEL testWATCH
(integer) 1
127.0.0.1:6379> MUTLI
(error) ERR unknown command 'MUTLI'
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET testWATCH a
QUEUED
127.0.0.1:6379> SET testWATCH ccc
QUEUED
# 客户端2
127.0.0.1:6379> SET testWATCH abc
OK
# 客户端1
127.0.0.1:6379> EXEC
(nil)
127.0.0.1:6379> GET testWATCH
"abc"
# 只要有在 WATCH 之后在非事务中对 key 有操作就不可以,无论是你哪个客户端
127.0.0.1:6379> WATCH testWATCH
OK
127.0.0.1:6379> SET testWATCH a
OK
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET testWATCH qwe
QUEUED
127.0.0.1:6379> EXEC
(nil)
# 语法错误会造成整个事务无法执行
127.0.0.1:6379> WATCH testWATCH
OK
127.0.0.1:6379> MULTI
OK
127.0.0.1:6379> SET testWATCH aaa
QUEUED
127.0.0.1:6379> EXEC \
    (error) ERR unknown command 'EXEC\'
127.0.0.1:6379> EXEC
(error) EXECABORT Transaction discarded because of previous errors.

事务中错误处理

  1. 语法错误会造成整个事务无法执行(示例中 EXEC\ 命令错误)
  2. 运行时错误:非语法错误,只是使用命令方式不正确比如使用 SADD 操作字符类型等等,只是错误部分报错,其他正常执行,且最后不会回滚事务。

Redis 提供了简单的事务,之所以说它简单,主要是因为它不支持事务中的回滚特性,同时无法实现命令之间的逻辑关系计算,当然也体现了 Redis 的 “keep it simple” 的特性。

转载于:https://my.oschina.net/coderknock/blog/983233

相关文章:

  • 关于百度站长平台升级HTTPS认证工具不得不说的事
  • HttpClient 图讲解明
  • promise和async/await的异步调用方法
  • 记一个toJSONString异常
  • Python连接Oracle
  • php新手入门必读!
  • 如何查看配置文件.mobileprovision的UUID
  • MySQL中一个文档疏漏的分析测试(r13笔记第3天)
  • 使用swoole websocket 实现执行console php文件 把输出返回给浏览器
  • 复习
  • 初识activiti
  • canves 画视频
  • CentOS6.8安装mongodb3.0与备份脚本
  • C++传递不定参函数
  • Android笔记之网络状态推断
  • 230. Kth Smallest Element in a BST
  • Android 控件背景颜色处理
  • ES6--对象的扩展
  • EventListener原理
  • Java IO学习笔记一
  • JSDuck 与 AngularJS 融合技巧
  • Linux后台研发超实用命令总结
  • PermissionScope Swift4 兼容问题
  • React-flux杂记
  • Redis 懒删除(lazy free)简史
  • seaborn 安装成功 + ImportError: DLL load failed: 找不到指定的模块 问题解决
  • vue:响应原理
  • 创建一个Struts2项目maven 方式
  • 浮动相关
  • 入门级的git使用指北
  • 山寨一个 Promise
  • 译米田引理
  • 硬币翻转问题,区间操作
  • 3月27日云栖精选夜读 | 从 “城市大脑”实践,瞭望未来城市源起 ...
  • $refs 、$nextTic、动态组件、name的使用
  • (3)选择元素——(17)练习(Exercises)
  • (bean配置类的注解开发)学习Spring的第十三天
  • (delphi11最新学习资料) Object Pascal 学习笔记---第2章第五节(日期和时间)
  • (MATLAB)第五章-矩阵运算
  • (动态规划)5. 最长回文子串 java解决
  • (黑客游戏)HackTheGame1.21 过关攻略
  • (黑马出品_高级篇_01)SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式
  • (四)汇编语言——简单程序
  • (一)WLAN定义和基本架构转
  • (转)【Hibernate总结系列】使用举例
  • (转)为C# Windows服务添加安装程序
  • .bat批处理出现中文乱码的情况
  • .Net - 类的介绍
  • .NET 回调、接口回调、 委托
  • .NET 事件模型教程(二)
  • .NET(C#、VB)APP开发——Smobiler平台控件介绍:Bluetooth组件
  • :=
  • [ CTF ] WriteUp- 2022年第三届“网鼎杯”网络安全大赛(白虎组)
  • [.net 面向对象程序设计进阶] (19) 异步(Asynchronous) 使用异步创建快速响应和可伸缩性的应用程序...
  • [Angular] 笔记 18:Angular Router