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