事务是一个很重要的数据库
Redis 事务可以一次执行多个命令, 并且带有以下两个重要的特征:
一个事务从开始到执行会依次经历以下三个阶段:
以下是一个事务的例子, 它先以 MULTI 命令开始一个事务, 然后将多个命令入队到事务中, 最后由 EXEC 命令触发事务, 一并执行事务中的所有命令:
redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> SET book-name "Mastering C++ in 21 days"
QUEUED
redis 127.0.0.1:6379> GET book-name
QUEUED
redis 127.0.0.1:6379> SADD tag "C++" "Programming" "Mastering Series"
QUEUED
redis 127.0.0.1:6379> SMEMBERS tag
QUEUED
redis 127.0.0.1:6379> EXEC
1) OK
2) "Mastering C++ in 21 days"
3) (integer) 3
4) 1) "Mastering Series"
2) "C++"
3) "Programming"
我们可以执行 DISCARD 命令来取消一个事务,让事务回滚。示例如下:
redis 127.0.0.1:6379> SET age 20
OK
redis 127.0.0.1:6379> GET age
"20"
redis 127.0.0.1:6379> MULTI
OK
redis 127.0.0.1:6379> SET age 21
QUEUED
redis 127.0.0.1:6379> SET age 22
QUEUED
redis 127.0.0.1:6379> DISCARD
OK
redis 127.0.0.1:6379> GET age
"20"
该文章会更新,欢迎大家批评指正。
推荐一个零声学院免费公开课程,个人觉得老师讲得不错,
分享给大家:[Linux,Nginx,ZeroMQ,MySQL,Redis,
fastdfs,MongoDB,ZK,流媒体,CDN,P2P,K8S,Docker,
TCP/IP,协程,DPDK等技术内容,点击立即学习:
服务器课程:C++服务器