您好,欢迎访问一九零五行业门户网

使用redis缓存,缓存key值为区间值(可做处理),当传入区间中的一个区间数时,怎么找到对应的缓存

例如:
我现在有个一个数组
array(
'10000_20000'=>'上海', '20001_30200'=>'北京', '30201_30300'=>'天津', '30301_40000'=>'深圳'


现在,我要把数组中的每个值存到redis缓存中,缓存key值可以是数组key值经过任何处理之后的,这时我传入一个值38000,我想在缓存中找到key值含38000的缓存值,有什么好的办法吗
求大神指点啊!
回复内容: 例如:
我现在有个一个数组
array(
'10000_20000'=>'上海', '20001_30200'=>'北京', '30201_30300'=>'天津', '30301_40000'=>'深圳'


现在,我要把数组中的每个值存到redis缓存中,缓存key值可以是数组key值经过任何处理之后的,这时我传入一个值38000,我想在缓存中找到key值含38000的缓存值,有什么好的办法吗
求大神指点啊!
//如果只是数组key很多,但value不大,使用有序集合
$redis->zadd('key', 10000, '上海');$redis->zadd('key', 20001, '北京');$redis->zadd('key', 30201, '天津');$redis->zadd('key', 30301, '深圳');$redis->zadd('key', 40001, '非法');$index = 38000;$value = $redis->zrangebyscore('key', $index, '+inf', ['limit' => [0, 1]]); // 深圳
这个数据又没规律
我的想法,foreach,之后取出右边部分,去比较大小,如果刚好大于等于3800,就跳出循环,返回当前键值。
当然,格式必须跟你现在的一致,从小到大
redis-cli中有个命令行: keys [patten], patten可以是正则表达式,找以38000结尾的key命令为:keys *38000。对应的phpredis的方法名为:keys, getkeys,具体可以参考:keys&getkeys
其它类似信息

推荐信息