您的位置:首页技术文章
文章详情页

ThinkPHP5中如何使用redis

【字号: 日期:2022-06-10 18:59:03浏览:137作者:猪猪
目录
  • 配置
  • redis使用
    • string(字符串)
    • Hash(哈希)
    • List(列表)
    • Set(集合)
    • zset(有序集合)
  • 总结

    前提:因为本文主要围绕着在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);

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

    标签: PHP