• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

Nosql之Redis: 事务处理及操作命令

mysql 搞代码 4年前 (2022-01-09) 16次浏览 已收录 0个评论

multi 标记事务的开始,事务块内的多条命令先后顺序放进一个队列中,最后由exec执行. 时间复杂度:O(1) 返回值: 总返回OK discard 取消事务,放弃执行事务块所有命令.如正使用watch监视时,将取消所有监视. 时间复杂度:O(1) 返回值: 总返回OK watch 格式: wathc k

multi
标记事务的开始,事务块内的多条命令先后顺序放进一个队列中,最后由exec执行.
时间复杂度:O(1)
返回值: 总返回OK
discard
取消事务,放弃执行事务块所有命令.如正使用watch监视时,将取消所有监视.
时间复杂度:O(1)
返回值: 总返回OK

watch
格式: wathc key [key …]
指定待监控的KEY(可多个).如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。
时间复杂度:O(1)
返回值: 总返回OK

exec
执行所有事务本文来源gao.dai.ma.com搞@代*码#网块内的命令.(注前面提到的watch).
时间复杂度:
事务块内所有命令的时间复杂度的总和。
返回值:
事务块内所有命令的返回值,按命令执行的先后顺序排列。
当操作被打断时,返回空值 nil

=========================================事务正常情况下:#启动一个新事务redis 127.0.0.1:6379> multiOK#执行一条命令,从返回结果中可以看出没有立刻执行,而是加到事务队列中.redis 127.0.0.1:6379> set key_id 2QUEUED#如下两条同上redis 127.0.0.1:6379> incr key_idQUEUEDredis 127.0.0.1:6379> incr key_idQUEUED#提交事务redis 127.0.0.1:6379> exec1) OK2) (integer) 33) (integer) 4=======================================#监视 key ,且事务成功执行:redis 127.0.0.1:6379> watch key_idOKredis 127.0.0.1:6379> multiOKredis 127.0.0.1:6379> incr key_idQUEUEDredis 127.0.0.1:6379> incr key_idQUEUEDredis 127.0.0.1:6379> exec1) (integer) 52) (integer) 6========================================# 监视 key ,且事务被打断redis 127.0.0.1:6379> watch key_idOKredis 127.0.0.1:6379> multiOK#在这之前另一户端执行过 set key_id 10redis 127.0.0.1:6379> set key_id 12QUEUED# 因 key_id 被修改,事务执行失败redis 127.0.0.1:6379> exec(nil)redis 127.0.0.1:6379> get key_id"10"==========================================#事务中出错redis 127.0.0.1:6379> multiOKredis 127.0.0.1:6379> set key_id 14QUEUEDredis 127.0.0.1:6379> set nma(error) ERR wrong number of arguments for 'set' command#从此处可以看出,redis出错时,没有回滚.其它命令还是照常执行.这也是redis事务中需要注意的redis 127.0.0.1:6379> exec1) OK


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:Nosql之Redis: 事务处理及操作命令
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址