Redis 事务 命令

目录

  • [1.Redis Exec 命令 - 执行所有事务块内的命令。](#1.Redis Exec 命令 - 执行所有事务块内的命令。)
    • 简介
    • 语法
      • [可用版本: >= 1.2.0](#可用版本: >= 1.2.0)
      • [返回值: 事务块内所有命令的返回值,按命令执行的先后顺序排列。 当操作被打断时,返回空值 nil 。](#返回值: 事务块内所有命令的返回值,按命令执行的先后顺序排列。 当操作被打断时,返回空值 nil 。)
    • 示例
  • [2.Redis Watch 命令 - 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。](#2.Redis Watch 命令 - 监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断。)
    • 简介
    • 语法
      • [可用版本: >= 2.2.0](#可用版本: >= 2.2.0)
      • [返回值: 总是返回 OK 。](#返回值: 总是返回 OK 。)
    • 示例
  • [3.Redis Discard 命令 - 取消事务,放弃执行事务块内的所有命令。](#3.Redis Discard 命令 - 取消事务,放弃执行事务块内的所有命令。)
    • 简介
    • 语法
      • [可用版本: >= 2.0.0](#可用版本: >= 2.0.0)
      • [返回值: 总是返回 OK 。](#返回值: 总是返回 OK 。)
    • 示例
  • [4.Redis Unwatch 命令 - 取消 WATCH 命令对所有 key 的监视。](#4.Redis Unwatch 命令 - 取消 WATCH 命令对所有 key 的监视。)
    • 简介
    • 语法
      • [可用版本: >= 2.2.0](#可用版本: >= 2.2.0)
      • [返回值: 总是返回 OK 。](#返回值: 总是返回 OK 。)
    • 示例
  • [5.Redis Multi 命令 - 标记一个事务块的开始。](#5.Redis Multi 命令 - 标记一个事务块的开始。)
    • 简介
    • 语法
      • [可用版本: >= 1.2.0](#可用版本: >= 1.2.0)
      • [返回值: 总是返回 OK 。](#返回值: 总是返回 OK 。)
    • 示例
  • 总结

1.Redis Exec 命令 - 执行所有事务块内的命令。

简介

复制代码
Redis Exec 命令用于执行所有事务块内的命令。Redis 事务

语法

复制代码
redis 127.0.0.1:6379> Exec

可用版本: >= 1.2.0

返回值: 事务块内所有命令的返回值,按命令执行的先后顺序排列。 当操作被打断时,返回空值 nil 。

示例

shell 复制代码
# 事务被成功执行

redis 127.0.0.1:6379> MULTI
OK

redis 127.0.0.1:6379> INCR user_id
QUEUED

redis 127.0.0.1:6379> INCR user_id
QUEUED

redis 127.0.0.1:6379> INCR user_id
QUEUED

redis 127.0.0.1:6379> PING
QUEUED

redis 127.0.0.1:6379> EXEC
1) (integer) 1
2) (integer) 2
3) (integer) 3
4) PONG


# 监视 key ,且事务成功执行

redis 127.0.0.1:6379> WATCH lock lock_times
OK

redis 127.0.0.1:6379> MULTI
OK

redis 127.0.0.1:6379> SET lock "huangz"
QUEUED

redis 127.0.0.1:6379> INCR lock_times
QUEUED

redis 127.0.0.1:6379> EXEC
1) OK
2) (integer) 1


# 监视 key ,且事务被打断

redis 127.0.0.1:6379> WATCH lock lock_times
OK

redis 127.0.0.1:6379> MULTI
OK

redis 127.0.0.1:6379> SET lock "joe"        # 就在这时,另一个客户端修改了 lock_times 的值
QUEUED

redis 127.0.0.1:6379> INCR lock_times
QUEUED

redis 127.0.0.1:6379> EXEC                  # 因为 lock_times 被修改, joe 的事务执行失败
(nil)

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

简介

复制代码
Redis Watch 命令用于监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断Redis 事务

语法

复制代码
redis 127.0.0.1:6379> Watch

可用版本: >= 2.2.0

返回值: 总是返回 OK 。

示例

shell 复制代码
redis> WATCH lock lock_times
OK

3.Redis Discard 命令 - 取消事务,放弃执行事务块内的所有命令。

简介

复制代码
Redis Discard 命令用于取消事务,放弃执行事务块内的所有命令。Redis 事务

语法

复制代码
redis 127.0.0.1:6379> DISCARD

可用版本: >= 2.0.0

返回值: 总是返回 OK 。

示例

shell 复制代码
redis 127.0.0.1:6379> MULTI
OK

redis 127.0.0.1:6379> PING
QUEUED

redis 127.0.0.1:6379> SET greeting "hello"
QUEUED

redis 127.0.0.1:6379> DISCARD
OK

4.Redis Unwatch 命令 - 取消 WATCH 命令对所有 key 的监视。

简介

复制代码
Redis Unwatch 命令用于取消 WATCH 命令对所有 key 的监视。Redis 事务

语法

复制代码
redis 127.0.0.1:6379> UNWATCH

可用版本: >= 2.2.0

返回值: 总是返回 OK 。

示例

shell 复制代码
redis 127.0.0.1:6379> WATCH lock lock_times
OK

redis 127.0.0.1:6379> UNWATCH
OK

5.Redis Multi 命令 - 标记一个事务块的开始。

简介

复制代码
事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令原子性(atomic)地执行。Redis Multi 命令用于标记一个事务块的开始。Redis 事务

语法

复制代码
redis 127.0.0.1:6379> Multi

可用版本: >= 1.2.0

返回值: 总是返回 OK 。

示例

shell 复制代码
redis 127.0.0.1:6379> MULTI            # 标记事务开始
OK

redis 127.0.0.1:6379> INCR user_id     # 多条命令按顺序入队
QUEUED

redis 127.0.0.1:6379> INCR user_id
QUEUED

redis 127.0.0.1:6379> INCR user_id
QUEUED

redis 127.0.0.1:6379> PING
QUEUED

redis 127.0.0.1:6379> EXEC             # 执行
1) (integer) 1
2) (integer) 2
3) (integer) 3
4) PONG

总结

相关推荐
廋到被风吹走2 小时前
【数据库】【MySQL】InnoDB外键解析:约束机制、性能影响与最佳实践
android·数据库·mysql
掘根2 小时前
【消息队列】交换机数据管理实现
网络·数据库
Logic1012 小时前
《Mysql数据库应用》 第2版 郭文明 实验6 数据库系统维护核心操作与思路解析
数据库·sql·mysql·学习笔记·计算机网络技术·形考作业·国家开放大学
AI Echoes3 小时前
构建一个LangChain RAG应用
数据库·python·langchain·prompt·agent
@nengdoudou3 小时前
KingbaseES支持 mysql 的find_in_set函数
数据库·mysql
摇滚侠3 小时前
面试实战 问题三十三 Spring 事务常用注解
数据库·spring·面试
梁萌3 小时前
保姆级的MySQL执行计划(Explain)解读
数据库·mysql·explain·执行计划
JIngJaneIL3 小时前
基于Java+ vue智慧医药系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
+VX:Fegn08954 小时前
计算机毕业设计|基于springboot + vue图书管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
杨云龙UP5 小时前
MySQL 8.0.x InnoDB 写入链路优化:Redo Log 与 Buffer Pool 扩容与缓冲区调优实战记录-20251029
linux·运维·数据库·sql·mysql