zoukankan      html  css  js  c++  java
  • redis实现区间查询

    ###redis实现区间查询
    在实际开发中经常遇到这样需求:服务端对于客户端不同的版本区间会做些不同的配置,那么客户端一个版本过来怎么快速的定位是属于哪个版本区间呢?可以利用`Sorted Sets`的`zrangebyscore`命令。
    ```
    zadd myset 1011 v1_start
    zadd myset 1015 v1_end
    zadd myset 1018 v2_start
    zadd myset 1023 v2_end
    ```
    如上我们像myset里插入了4条数据,代表的意思是版本区间v1是从1011-1015版本,版本区间v2是从1018-1023版本。
    注:redis的Sorted Sets需要score必须为float型,所以这里需要对版本号做一个等价的转换。
    那么我现在如何判断1014版本属于哪个区间呢,使用zrangebyscore如下操作:
    ```
    zrangebyscore myset 1014 +inf LIMIT 0 1
    1)v1_end
    ```
    返回v1_end说明1014属于版本区间1,上面的这个命令的意思是在myset中查找第一个score值大于等于1014的member,如果我们查找一个不在区间内的版本,比如1016:
    ```
    zrangebyscore myset 1014 +inf LIMIT 0 1
    1)v2_start
    ```
    返回v2_start说明它不已有的版本区间内。
    关于该命令的具体用法可以看这里[这里][1]。
    
    不过这种用法不适合那些区间之间存在重叠的场景。
    
    ###实现一个hash里不同的field拥有不同expire的场景 目前redis不支持这个特性,这是redis的设计原则决定的。可以在Hash中每个field对应的value本身含有时间的信息,让应用自己去理解和处理。 ![][2]
    ###在redis里维护自增长的主键 有时候可能需要在redis的多个数据结构之间维护一个类似关系型数据库中的自增长主键,可以利用Sorted Sets的ZINCRBY ``` zincrby myset 1 config_no 1)2 ``` 上面的意思是将myset中的config_no的score值加1,让key不存在或member不存在时上面的命令相当于: ``` zadd myset 1 config_no 1)1 ``` [1]: http://manual.csser.com/redis/sorted_set/zrangebyscore.html [2]: http://zhanjindong.info/wp-content/uploads/2014/02/11.png
  • 相关阅读:
    DNS 截持模拟及环境搭建
    Ant、Gradle、Python三种打包方式的介绍
    oc/c/c++混编老文,写的很好,mark
    好文!关于iOS下的正则表达式实战案例
    Java设计模式——享元模式
    Java 消息机制之回调详解
    windows版爬取csdn
    14.6.2 Configuring InnoDB for Read-Only Operation
    dump iot表
    heap表按字符串和数值型排序规则
  • 原文地址:https://www.cnblogs.com/zhanjindong/p/3549994.html
Copyright © 2011-2022 走看看