• Redis 事物


    MULTI 、 EXEC 、 DISCARD 和 WATCH 是 Redis 事务的基础。

    Multi 和 Exec


    Multi:开启一个事务,它总是返回 OK 。执行之后, 客户端可以继续向服务器发送任意多条命令, 这些命令不会立即被执行, 而是被放到一个队列中, 当 EXEC 命令被调用时, 所有队列中的命令才会被执行。

    另一方面, 通过调用 DISCARD , 客户端可以清空事务队列, 并放弃执行事务。

    下面我们试一试这两个命令

    以年龄为例:

    1.开启事物

    2.修改数据

    这个时候我们再查看一次年龄,发现还是25,说明事物还没被提交前所有的修改操作都不会生效

    3.提交事物

    再次查看数据,事务提交后修改操作生效了

    Watch


    被 WATCH 的键会被监视,并会发觉这些键是否被改动过了。 如果有至少一个被监视的键在 EXEC 执行之前被修改了, 那么整个事务都会被取消, EXEC 返回空多条批量回复(null multi-bulk reply)来表示事务已经失败。

    我们再来举个例子

    还是以年龄为例:

    当前age是23

    1.watch:监视你,接下来age这个数据只能在我这个线程里面操作了,其他地方动了这个数据就会报警

    2.开启事物

    3.这时候新开一个窗口,修改age

    4.回到原先的窗口,现在数据已经被其他线程修改了,我们看下再修改还会有效么

    5.提交事务

    这次的结果不是ok,说明watch监视成功了,我们再看看当前age是多少呢

    这就是watch的用法

    Discard


    当执行 DISCARD 命令时, 事务会被放弃, 事务队列会被清空, 并且客户端会从事务状态中退出:

    这个命令比较简单,这里就不做过多的解释了,直接举例子了

    以上就是redis事物的基本操作

  • 相关阅读:
    第六课 变量和常量
    第六课 实型(浮点型)
    第五课 字符型数据 (主函数冲突)
    第四课 整型数据(主函数冲突)
    第二课(需订正)运行失败解决方法
    第三课 数据类型分类(关键字)
    第二课
    第一课
    贝叶斯滤波与卡尔曼滤波第九讲笔记《粒子滤波》
    贝叶斯滤波与卡尔曼滤波第八讲代码
  • 原文地址:https://www.cnblogs.com/xmzJava/p/8461295.html
Copyright © 2020-2023  润新知