Transaction(事务)
1、WATCH
Redis Watch 命令用于监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断
语法:
redis 127.0.0.1:6379> Watch
返回值: 总是返回 OK
可用版本:>= 2.2.0
时间复杂度:O(1)
具体实例:
$redis -> watch(‘number‘);
2、UNWATCH
Redis Unwatch 命令用于取消 WATCH 命令对所有 key 的监视。
语法:
redis 127.0.0.1:6379> UNWATCH
返回值: 总是返回 OK
可用版本:>= 2.2.0
时间复杂度:O(1)
具体实例:
$redis -> watch(‘number‘); $redis -> unwatch();
3、MULTI
Redis Multi 命令用于标记一个事务块的开始。
事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令原子性(atomic)地执行。
语法:
redis 127.0.0.1:6379> Multi
返回值: 总是返回 OK
可用版本:>= 1.2.0
时间复杂度:O(1)
具体实例:
$redis -> multi();
4、EXEC
Redis Exec 命令用于执行所有事务块内的命令。
语法:
redis 127.0.0.1:6379> Exec
返回值: 事务块内所有命令的返回值,按命令执行的先后顺序排列。 当操作被打断时,返回空值 nil
可用版本:>= 1.2.0
时间复杂度:事务块内所有命令的时间复杂度的总和
具体实例:
<?php $redis = new redis(); $redis -> connect(‘127.0.0.1‘,6379); $redis -> flushAll(); $redis -> watch(‘number‘);$redis -> multi(); $redis -> set(‘favorite_fruit‘,‘cherry‘); $redis -> incrBy(‘number‘,3); $redis -> get(‘favorite_fruit‘); $redis -> ping(); var_dump($redis -> exec()); //array (size=4) // 0 => boolean true // 1 => int 3 // 2 => string ‘cherry‘ (length=6) // 3 => string ‘+PONG‘ (length=5)
5、DISCARD
Redis Discard 命令用于取消事务放弃执行事务块内的所有命令。
语法:
redis 127.0.0.1:6379> DISCARD
返回值: 总是返回 OK 。
可用版本:>= 2.0.0
时间复杂度:O(1)。
具体实例:
<?php $redis = new redis(); $redis -> connect(‘127.0.0.1‘,6379); $redis -> flushAll(); $redis -> watch(‘number‘); $redis -> unwatch(); $redis -> multi(); $redis -> set(‘favorite_fruit‘,‘cherry‘); $redis -> incrBy(‘number‘,3); $redis -> get(‘favorite_fruit‘); $redis -> ping(); $redis -> discard(); // 取消事务 var_dump($redis -> exec()); // null
原文地址:https://www.cnblogs.com/tiger-lzl/p/9995859.html