ThinkPHP5中如何使用redis

前提:因為本文主要圍繞著在thinkPHP5中使用redis的,所以關於redis的安裝就不特意說明瞭,不過在這稍微提醒一下,安裝完redis後務必要開啟php.ini擴展,否則還是無法使用redis的。

配置

1.會用ThinkPHP5的同學們都知道,TinkPHP5中封裝瞭緩存類,我們隻需要在/application/congfig.php中的cache中填入緩存配置項就可以使用瞭(如下所示)。

2.從/thinkphp/library/think/cache/driver/Redis.php文件可知這裡封裝的redis緩存隻能使用redis的string基本類型,如果要使用哈希或隊列等復合數據類型的話是不行的。

看緩存類/thinkphp/library/think/cache/Driver.php會發現handler方法會返回句柄,所以我們隻要在我們使用redis的地方獲得這個句柄就可以使用redis的所有數據類型瞭,因此可以在/thinkphp/library/think/Cache.php中添加獲取句柄方法getHandler

	/**
     * 返回句柄對象,可執行其它高級方法
     *
     * @access public
     * @return object
     */
    public function handler()
    {
        return $this->handler;
    }
	/*
    *  獲取句柄
    * @param  
    */
    public static function getHandler()
    {
        return self::init();
    }

redis使用

string(字符串)

基本的類型,一個 key 對應一個 value。

一個string 類型的值最大能存儲 512MB

圖解:

// 創建數據
$redis->set('key', 'value');// 獲取數據
$value = $redis->get('key');
echo $value . PHP_EOL;// 修改數據,與創建數據一致,即覆蓋數據
$redis->set('key', 'value2');
echo $redis->get('key') . PHP_EOL;// 追加數據
$redis->append('key', '_value2');
echo $redis->get('key') . PHP_EOL;// 刪除數據
$redis->del('key');
// $redis->delete('key');
var_dump($redis->get('key'));// 創建數據,帶有效期
$redis->set('timeout_key', 'timeout_value', 5);
$redis->setex('timeout_key', 5, 'timeout_value');
// 獲取數據的有效期
echo $redis->ttl('timeout_key') . PHP_EOL;// 判斷是否已經寫入,未寫入則寫入
$redis->set('unique_key', 'unique_value');
if (!$redis->setnx('unique_key', 'unique_value')) {
	echo $redis->get('unique_key') . PHP_EOL;
}// 批量創建
$multi = ['key1' => 'value1', 'key2' => 'value2', 'key3' => 'value3'];
$redis->mset($multi);// 批量獲取
$result = $redis->mget(array_keys($multi));
var_dump($result);

Hash(哈希)

hash 是一個鍵值(key=>value)對集合;是一個 string 類型的 field 和 value 的映射表,hash 特別適合用於存儲對象。

每個 hash 可以存儲 2^32 -1 鍵值對(40多億)

圖解 :

// 創建 hash 表
// 向名字叫 'hash' 的 hash表 中添加元素 ['key1' => 'val1']
$redis->hSet('hash', 'key1', 'val1');// 獲取 hash表 中鍵名是 key1 的值
echo $redis->hGet('hash', 'key1') . PHP_EOL;// 獲取 hash表的元素個數
echo $redis->hLen('hash') . PHP_EOL;// 獲取 hash表 中所有的鍵
$keys = $redis->hKeys('hash');
var_dump($keys);// 獲取 hash表 中所有的值
$vals = $redis->hVals('hash');
var_dump($vals);// 獲取 hash表 中所有的鍵值對
// 不推薦使用這種方法獲取全部數據,會導致服務器執行超時,推薦方法後邊會詳細介紹
// $all = $redis->hGetAll('hash');
// var_dump($all);// 判斷 hash 表中是否存在鍵名是 key2 的元素
$bool = $redis->hExists('hash', 'key2');
echo $bool ? '存在' : '不存在' . PHP_EOL;// 批量添加元素
$redis->hMset('hash', ['key2' => 'val2', 'key3' => 'val3']);// 批量獲取元素
$hashes = $redis->hMGet('hash', ['key1', 'key2', 'key3']);
var_dump($hashes);// 刪除 hash表
$redis->del('hash');

List(列表)

列表是簡單的字符串列表,按照插入順序排序。你可以添加一個元素到列表的頭部(左邊)或者尾部(右邊)。list類型經常會被用於消息隊列的服務,以完成多程序之間的消息交換。列表最多可存儲 2^32 – 1 元素 (4294967295, 每個列表可存儲40多億)。

圖解 :

// 向隊列左側加入元素
$redis->lPush('lists', 'X');
$redis->lPush('lists', 'X');
// 向隊列右側加入元素
$redis->rPush('lists', 'Z');// 將索引為1的數據修改為 Y
$redis->lSet('lists', 1, 'Y');// 獲取 list 長度
$length = $redis->lLen('lists');
echo $length;// 遍歷 list
$lists = $redis->lRange('lists', 0, $length - 1);
dump($lists);// 從左側出隊一個元素(獲取並刪除)
$x = $redis->lPop('lists');
echo $x . PHP_EOL;
// 從右側出隊一個元素(獲取並刪除)
$z = $redis->rPop('lists');
echo $z . PHP_EOL;// 獲取左側第一個元素
$y = $redis->lIndex('lists', 0);
echo $y . PHP_EOL;// 刪除隊列
$redis->del('lists');

Set(集合)

Redis的Set是string類型的無序集合。

和列表一樣,在執行插入和刪除和判斷是否存在某元素時,效率是很高的。

集合最大的優勢在於可以進行交集並集差集操作。

Set可包含的最大元素數量是4294967295(40多億)。

集合是通過哈希表實現的,所以添加,刪除,查找的復雜度都是O(1)。

圖解 :

// 創建集合
$redis->sAdd('sets', 'value1', 'value2');
// 以數組形式創建集合
$redis->sAddArray('sets2', ['value1', 'value2', 'value3']);// 取兩個集合的並集
$union = $redis->sUnion('sets', 'sets2');
// 取兩個集合的差集
$diff = $redis->sDiff('sets', 'sets2');
// 取兩個集合的交集
$inter = $redis->sInter('sets', 'sets2');var_dump($union, $diff, $inter);// 獲取集合數量
$card = $redis->sCard('sets');
echo $card . PHP_EOL;// 獲取集合中全部元素
// 不推薦使用這種方法獲取全部數據,會導致服務器執行超時,推薦方法後邊會詳細介紹
$sets = $redis->sMembers('sets');
var_dump($sets);// 判斷元素是否是集合中的成員
$isMember = $redis->sIsMember('sets', 'value2');
var_dump($isMember);// 刪除集合中的元素
$redis->sRem('sets', 'value2');
var_dump($redis->sMembers('sets'));// 隨機獲取一個元素
echo $redis->sRandMember('sets');// 隨機獲取一個元素並從集合中刪除
echo $redis->sPop('sets');// 刪除集合
$redis->del('sets', 'sets2');

zset(有序集合)

Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復的成員。

不同的是每個元素都會關聯一個double類型的分數。

redis正是通過分數來為集合中的成員進行從小到大的排序。

// 添加成員
$redis->zAdd('zset', 95, '小明');
$redis->zAdd('zset', 99, '小剛');
$redis->zAdd('zset', 100, '小紅');// 統計成員個數
echo $redis->zCard('zset') . PHP_EOL;// 獲取某個成員的分數
$score = $redis->zScore('zset', '小明');
echo $score . PHP_EOL;// 獲取某個成員的排名
$rank = $redis->zRank('zset', '小明'); // 從低到高排序的名次
$revRank = $redis->zRevRank('zset', '小明'); // 從高到低排序的名次
echo $rank . PHP_EOL;
echo $revRank . PHP_EOL;// 給指定成員增加分數
$redis->zIncrBy('zset', 1, '小明'); // 給小明加一分// 返回指定排名范圍的成員
$range = $redis->zRange('zset', 0, 9, true); // 返回分數從低到高排序的前10名及分數
$revRange = $redis-> zRevRange('zset', 0, 9, true); // 返回分數從高到低排序的前10名及分數
var_dump($range);
var_dump($revRange);// 刪除成員
$redis->zRem('zet', '小明');// 返回指定分數范圍的成員
$rangeByScore = $redis->zRangeByScore('zet', 98, 100); // 返回指定分數范圍內從低到高排序的成員
$revRangeByScore = $redis->zRevRangeByScore('zet', 98, 100); // 返回指定分數范圍內從高到低排序的成員
var_dump($rangeByScore);
var_dump($revRangeByScore);

總結

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: