最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:懂视网 责编:小采 时间:2020-11-09 13:23:50
文档

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

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

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
执行所有事务块内的命令.(注前面提到的watch).
时间复杂度:
事务块内所有命令的时间复杂度的总和。
返回值:
事务块内所有命令的返回值,按命令执行的先后顺序排列。
当操作被打断时,返回空值 nil

=========================================
事务正常情况下:
#启动一个新事务
redis 127.0.0.1:6379> multi
OK
#执行一条命令,从返回结果中可以看出没有立刻执行,而是加到事务队列中.
redis 127.0.0.1:6379> set key_id 2
QUEUED
#如下两条同上
redis 127.0.0.1:6379> incr key_id
QUEUED
redis 127.0.0.1:6379> incr key_id
QUEUED
#提交事务
redis 127.0.0.1:6379> exec
1) OK
2) (integer) 3
3) (integer) 4
=======================================
#监视 key ,且事务成功执行:
redis 127.0.0.1:6379> watch key_id
OK
redis 127.0.0.1:6379> multi
OK
redis 127.0.0.1:6379> incr key_id
QUEUED
redis 127.0.0.1:6379> incr key_id
QUEUED
redis 127.0.0.1:6379> exec
1) (integer) 5
2) (integer) 6
========================================
# 监视 key ,且事务被打断
redis 127.0.0.1:6379> watch key_id
OK
redis 127.0.0.1:6379> multi
OK
#在这之前另一户端执行过 set key_id 10
redis 127.0.0.1:6379> set key_id 12
QUEUED
# 因 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> multi
OK
redis 127.0.0.1:6379> set key_id 14
QUEUED
redis 127.0.0.1:6379> set nma
(error) ERR wrong number of arguments for 'set' command
#从此处可以看出,redis出错时,没有回滚.其它命令还是照常执行.这也是redis事务中需要注意的
redis 127.0.0.1:6379> exec
1) OK

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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

Nosql之Redis:事务处理及操作命令:multi 标记事务的开始,事务块内的多条命令先后顺序放进一个队列中,最后由exec执行. 时间复杂度:O(1) 返回值: 总返回OK discard 取消事务,放弃执行事务块所有命令.如正使用watch监视时,将取消所有监视. 时间复杂度:O(1) 返回值: 总返回OK watc
推荐度:
标签: 操作 命令 事务
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top