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事物的基本操作