zoukankan      html  css  js  c++  java
  • 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事物的基本操作

  • 相关阅读:
    IOS创建Button简单实例
    IOSActionSheet、AlertView、Slider、Switch的简单使用
    IOS翻转注意
    [教程]iOS 4 开发的好东西 (资料)url
    Proxy和Decorator模式
    Using JNDI connecting DB
    影片“One Day”,还不错
    Minabased TCP server examples
    MySQL vs. Oracle on sequence
    Java DB and JDBC(Embedded Derby)
  • 原文地址:https://www.cnblogs.com/xmzJava/p/8461295.html
Copyright © 2011-2022 走看看