redis 在 php 中的应用(事务 [ Transaction ] 篇)
本文为我阅读了 redis参考手册 之后编写,注意 php_redis 和 redis-cli 的区别(主要是返回值类型和参数用法)
目录:
Transaction(事务) | ||||
WATCH | UNWATCH | MULTI | EXEC | DISCARD |
Transaction(事务)
Redis Watch 命令用于监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断
语法:
redis 127.0.0.1:6379> Watch
返回值: 总是返回 OK
可用版本:>= 2.2.0
时间复杂度:O(1)
具体实例:
$redis -> watch('number');
Redis Unwatch 命令用于取消 WATCH 命令对所有 key 的监视。
语法:
redis 127.0.0.1:6379> UNWATCH
返回值: 总是返回 OK
可用版本:>= 2.2.0
时间复杂度:O(1)
具体实例:
$redis -> watch('number'); $redis -> unwatch();
Redis Multi 命令用于标记一个事务块的开始。
事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令原子性(atomic)地执行。
语法:
redis 127.0.0.1:6379> Multi
返回值: 总是返回 OK
可用版本:>= 1.2.0
时间复杂度:O(1)
具体实例:
$redis -> multi();
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)
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
如有转载,请注明出处:http://www.cnblogs.com/chrdai/p/6856619.html