ThinkPHP5中如何使用redis
目錄
- 配置
- redis使用
- string(字符串)
- Hash(哈希)
- List(列表)
- Set(集合)
- zset(有序集合)
- 總結(jié)
前提:因?yàn)楸疚闹饕獓@著在thinkPHP5中使用redis的,所以關(guān)于redis的安裝就不特意說明了,不過在這稍微提醒一下,安裝完redis后務(wù)必要開啟php.ini擴(kuò)展,否則還是無法使用redis的。
配置
1.會(huì)用ThinkPHP5的同學(xué)們都知道,TinkPHP5中封裝了緩存類,我們只需要在/application/congfig.php中的cache中填入緩存配置項(xiàng)就可以使用了(如下所示)。
2.從/thinkphp/library/think/cache/driver/Redis.php文件可知這里封裝的redis緩存只能使用redis的string基本類型,如果要使用哈希或隊(duì)列等復(fù)合數(shù)據(jù)類型的話是不行的。
看緩存類/thinkphp/library/think/cache/Driver.php會(huì)發(fā)現(xiàn)handler方法會(huì)返回句柄,所以我們只要在我們使用redis的地方獲得這個(gè)句柄就可以使用redis的所有數(shù)據(jù)類型了,因此可以在/thinkphp/library/think/Cache.php中添加獲取句柄方法getHandler
/** * 返回句柄對(duì)象,可執(zhí)行其它高級(jí)方法 * * @access public * @return object */ public function handler() {return $this->handler; }
/* * 獲取句柄 * @param */ public static function getHandler() {return self::init(); }
redis使用
string(字符串)
基本的類型,一個(gè) key 對(duì)應(yīng)一個(gè) value。
一個(gè)string 類型的值最大能存儲(chǔ) 512MB
圖解:
// 創(chuàng)建數(shù)據(jù)$redis->set("key", "value");// 獲取數(shù)據(jù)$value = $redis->get("key");echo $value . PHP_EOL;// 修改數(shù)據(jù),與創(chuàng)建數(shù)據(jù)一致,即覆蓋數(shù)據(jù)$redis->set("key", "value2");echo $redis->get("key") . PHP_EOL;// 追加數(shù)據(jù)$redis->append("key", "_value2");echo $redis->get("key") . PHP_EOL;// 刪除數(shù)據(jù)$redis->del("key");// $redis->delete("key");var_dump($redis->get("key"));// 創(chuàng)建數(shù)據(jù),帶有效期$redis->set("timeout_key", "timeout_value", 5);$redis->setex("timeout_key", 5, "timeout_value");// 獲取數(shù)據(jù)的有效期echo $redis->ttl("timeout_key") . PHP_EOL;// 判斷是否已經(jīng)寫入,未寫入則寫入$redis->set("unique_key", "unique_value");if (!$redis->setnx("unique_key", "unique_value")) { echo $redis->get("unique_key") . PHP_EOL;}// 批量創(chuàng)建$multi = ["key1" => "value1", "key2" => "value2", "key3" => "value3"];$redis->mset($multi);// 批量獲取$result = $redis->mget(array_keys($multi));var_dump($result);
Hash(哈希)
hash 是一個(gè)鍵值(key=>value)對(duì)集合;是一個(gè) string 類型的 field 和 value 的映射表,hash 特別適合用于存儲(chǔ)對(duì)象。
每個(gè) hash 可以存儲(chǔ) 2^32 -1 鍵值對(duì)(40多億)
圖解 :
// 創(chuàng)建 hash 表// 向名字叫 "hash" 的 hash表 中添加元素 ["key1" => "val1"]$redis->hSet("hash", "key1", "val1");// 獲取 hash表 中鍵名是 key1 的值echo $redis->hGet("hash", "key1") . PHP_EOL;// 獲取 hash表的元素個(gè)數(shù)echo $redis->hLen("hash") . PHP_EOL;// 獲取 hash表 中所有的鍵$keys = $redis->hKeys("hash");var_dump($keys);// 獲取 hash表 中所有的值$vals = $redis->hVals("hash");var_dump($vals);// 獲取 hash表 中所有的鍵值對(duì)// 不推薦使用這種方法獲取全部數(shù)據(jù),會(huì)導(dǎo)致服務(wù)器執(zhí)行超時(shí),推薦方法后邊會(huì)詳細(xì)介紹// $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(列表)
列表是簡單的字符串列表,按照插入順序排序。你可以添加一個(gè)元素到列表的頭部(左邊)或者尾部(右邊)。list類型經(jīng)常會(huì)被用于消息隊(duì)列的服務(wù),以完成多程序之間的消息交換。列表最多可存儲(chǔ) 2^32 - 1 元素 (4294967295, 每個(gè)列表可存儲(chǔ)40多億)。
圖解 :
// 向隊(duì)列左側(cè)加入元素$redis->lPush("lists", "X");$redis->lPush("lists", "X");// 向隊(duì)列右側(cè)加入元素$redis->rPush("lists", "Z");// 將索引為1的數(shù)據(jù)修改為 Y$redis->lSet("lists", 1, "Y");// 獲取 list 長度$length = $redis->lLen("lists");echo $length;// 遍歷 list$lists = $redis->lRange("lists", 0, $length - 1);dump($lists);// 從左側(cè)出隊(duì)一個(gè)元素(獲取并刪除)$x = $redis->lPop("lists");echo $x . PHP_EOL;// 從右側(cè)出隊(duì)一個(gè)元素(獲取并刪除)$z = $redis->rPop("lists");echo $z . PHP_EOL;// 獲取左側(cè)第一個(gè)元素$y = $redis->lIndex("lists", 0);echo $y . PHP_EOL;// 刪除隊(duì)列$redis->del("lists");
Set(集合)
Redis的Set是string類型的無序集合。
和列表一樣,在執(zhí)行插入和刪除和判斷是否存在某元素時(shí),效率是很高的。
集合最大的優(yōu)勢在于可以進(jìn)行交集并集差集操作。
Set可包含的最大元素?cái)?shù)量是4294967295(40多億)。
集合是通過哈希表實(shí)現(xiàn)的,所以添加,刪除,查找的復(fù)雜度都是O(1)。
圖解 :
// 創(chuàng)建集合$redis->sAdd("sets", "value1", "value2");// 以數(shù)組形式創(chuàng)建集合$redis->sAddArray("sets2", ["value1", "value2", "value3"]);// 取兩個(gè)集合的并集$union = $redis->sUnion("sets", "sets2");// 取兩個(gè)集合的差集$diff = $redis->sDiff("sets", "sets2");// 取兩個(gè)集合的交集$inter = $redis->sInter("sets", "sets2");var_dump($union, $diff, $inter);// 獲取集合數(shù)量$card = $redis->sCard("sets");echo $card . PHP_EOL;// 獲取集合中全部元素// 不推薦使用這種方法獲取全部數(shù)據(jù),會(huì)導(dǎo)致服務(wù)器執(zhí)行超時(shí),推薦方法后邊會(huì)詳細(xì)介紹$sets = $redis->sMembers("sets");var_dump($sets);// 判斷元素是否是集合中的成員$isMember = $redis->sIsMember("sets", "value2");var_dump($isMember);// 刪除集合中的元素$redis->sRem("sets", "value2");var_dump($redis->sMembers("sets"));// 隨機(jī)獲取一個(gè)元素echo $redis->sRandMember("sets");// 隨機(jī)獲取一個(gè)元素并從集合中刪除echo $redis->sPop("sets");// 刪除集合$redis->del("sets", "sets2");
zset(有序集合)
Redis zset 和 set 一樣也是string類型元素的集合,且不允許重復(fù)的成員。
不同的是每個(gè)元素都會(huì)關(guān)聯(lián)一個(gè)double類型的分?jǐn)?shù)。
redis正是通過分?jǐn)?shù)來為集合中的成員進(jìn)行從小到大的排序。
// 添加成員$redis->zAdd("zset", 95, "小明");$redis->zAdd("zset", 99, "小剛");$redis->zAdd("zset", 100, "小紅");// 統(tǒng)計(jì)成員個(gè)數(shù)echo $redis->zCard("zset") . PHP_EOL;// 獲取某個(gè)成員的分?jǐn)?shù)$score = $redis->zScore("zset", "小明");echo $score . PHP_EOL;// 獲取某個(gè)成員的排名$rank = $redis->zRank("zset", "小明"); // 從低到高排序的名次$revRank = $redis->zRevRank("zset", "小明"); // 從高到低排序的名次echo $rank . PHP_EOL;echo $revRank . PHP_EOL;// 給指定成員增加分?jǐn)?shù)$redis->zIncrBy("zset", 1, "小明"); // 給小明加一分// 返回指定排名范圍的成員$range = $redis->zRange("zset", 0, 9, true); // 返回分?jǐn)?shù)從低到高排序的前10名及分?jǐn)?shù)$revRange = $redis-> zRevRange("zset", 0, 9, true); // 返回分?jǐn)?shù)從高到低排序的前10名及分?jǐn)?shù)var_dump($range);var_dump($revRange);// 刪除成員$redis->zRem("zet", "小明");// 返回指定分?jǐn)?shù)范圍的成員$rangeByScore = $redis->zRangeByScore("zet", 98, 100); // 返回指定分?jǐn)?shù)范圍內(nèi)從低到高排序的成員$revRangeByScore = $redis->zRevRangeByScore("zet", 98, 100); // 返回指定分?jǐn)?shù)范圍內(nèi)從高到低排序的成員var_dump($rangeByScore);var_dump($revRangeByScore);
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持。
