当前位置: 代码网 > it编程>编程语言>Php > ThinkPHP5中如何使用redis

ThinkPHP5中如何使用redis

2024年05月19日 Php 我要评论
前提:因为本文主要围绕着在thinkphp5中使用redis的,所以关于redis的安装就不特意说明了,不过在这稍微提醒一下,安装完redis后务必要开启php.ini扩展,否则还是无法使用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);

总结

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

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com