zoukankan      html  css  js  c++  java
  • Redis 5种主要数据类型和命令

    redis是键值对的数据库,有5中主要数据类型

    字符串类型(string),散列类型(hash),列表类型(list),集合类型(set),有序集合类型(zset)

     

    几个基本的命令:

    KEYS * 获得当前数据库的所有键

    EXISTS key [key ...]  判断键是否存在,返回个数,如果key有一样的也是叠加数

    DEL key [key ...]       删除键,返回删除的个数

    TYPE key                  获取减值的数据类型(string,hash,list,set,zset)

    FLUSHALL                清空所有数据库

    CONFIG [get、set]    redis配置

    -inf 负无穷

    +inf正无穷

     

    一:字符串类型string

    字符串类型是Redis的最基本类型,它可以存储任何形式的字符串。其它的四种类型都是字符串类型的不同形式。

    取值设值

    get、set 

    语法:GET keySET key value   value如果有空格需要双引号以示区分

    整数递增

     incr

    语法:INCR key    默认值为0,所以首先执行命令得到 1 ,不是整型提示错误

    增加指定的整数

     incrby    

        语法:INCRBY key increment

    整数递减

     decr

    语法:DECR key   默认值为0,所以首先执行命令得到 -1,不是整型提示错误

    减少指定的整数

     decrby  

         语法:DECRBY key increment

    增加指定浮点数

    incrbyfloat

    语法:INCRBYFLOAT key increment  INCR命令类似,只不过可以递增一个双精度浮点数

    向尾部追加值

     append

    语法:APPEND key value   redis客户端并不是输出追加后的字符串,而是输出字符串总长度

    获取字符串长度

     strlen 

     语法:STRLEN key  如果键不存在返回0,注意如果有中文时,一个中文长度是3redis是使用UTF-8编码中文的

    获取多个键值

    mget

     语法:MGET key [key ...]  例如:MGET key1 key2

    设置多个键值

    mset 

     语法:MSET key value [key value ...]  例如:MSET key1 1 key2 "hello redis"

    二进制指定位置值

     getbit

    语法:GETBIT key offset   例如:GETBIT key1 2 key1hello 返回 1,返回的值只有01,当key不存在或超出实际长度时为0

    设置二进制位置值

     setbit

    语法:SETBIT key offset value ,返回该位置的旧值

    二进制是1的个数

    bitcount

     语法:BITCOUNT key [start end] start end为开始和结束字节

    位运算

     bitop

     语法:BITOP operation destkey key [key ...]  operation支持ANDORXORNOT

    偏移

    bitpos

     语法:BITPOS key bit [start] [end]

     

              

    二:散列类型hash

    设置单个

    hset

    语法:HSET key field value,不存在时返回1,存在时返回0,没有更新和插入之分

    设置多个

     hmset

    语法:HMSET key field value [field value ...]

     读取单个:

    hget

    语法:HGET key field,不存在是返回null

    读取多个

    hmget

     语法:HMGET key field [field ...]

    读取全部

    hgetAll

     语法:HGETALL key,返回时字段和字段值的列表

    判断字段是否存在

    hexists

    语法:HEXISTS key field,存在返回1 ,不存在返回0

    字段不存在时赋值

    hsetnx

    语法:HSETNX key field value,与hset命令不同,hsetnx是键不存在时设置值

    增加数字

    hincrby

    语法:HINCRBY key field increment ,返回增加后的数,不是整数时会提示错误

    删除字段

    hdel

    语法:HDEL key field [field ...] ,返回被删除字段的个数

    只获取字段名

    hkeys

     语法:HKEYS key ,返回键的所有字段名

    只获取字段值

    hvals

    语法:HVALS key  ,返回键的所有字段值

    字段数量

    hlen

      语法:HLEN key ,返回字段总数

    三:列表类型(list

    内部使用双向链表实现,所以获取越接近两端的元素速度越快,但通过索引访问时会比较慢

    添加左边元素

     lpush

    语法:LPUSH key value [value ...]  ,返回添加后的列表元素的总个数

    添加右边元素

    rpush  

    语法:RPUSH key value [value ...]  ,返回添加后的列表元素的总个数

    移除左边第一个元素

    lpop

    语法:LPOP key  ,返回被移除的元素值

    移除右边第一个元素

    rpop

    语法:RPOP key ,返回被移除的元素值 

    列表元素个数

     llen

    语法:LLEN key, 不存在时返回0redis是直接读取现成的值,并不是统计个数

     获取列表片段

     

    lrange 

    语法:LRANGE key start stop,如果startstop靠后时返回空列表,0 -1 返回整个列表。 正数时:start 开始索引值,stop结束索引值(索引从0开始)。负数时:例如 lrange num -2 -1-2表示最右边第二个,-1表示最右边第一个

    删除指定值

    lrem 

    语法:LREM key count value,返回被删除的个数。  count>0,从左边开始删除前count个值为value的元素。  count<0,从右边开始删除前|count|个值为value的元素。  count=0,删除所有值为value的元素

    索引元素值

    lindex

    语法:LINDEX key index ,返回索引的元素值,-1表示从最右边的第一位

    设置元素值

    lset

    语法:LSET key index value

    保留列表片段

    ltrim  

    语法:LTRIM key start stopstarttop 参考lrange命令

    一个列表转移另一个列表

    rpoplpush

    语法:RPOPLPUSH source desctination ,从source列表转移到desctination列表,命令分两步看,首先source列表RPOP右移除,再desctination列表LPUSH

                                                       

    四:集合类型(set

    集合类型值具有唯一性,常用操作是向集合添加、删除、判断某个值是否存在,集合内部是使用值为空的散列表实现的。

     

    添加元素

     sadd  

    语法:SADD key member [member ...] ,向一个集合添加一个或多个元素,因为集合的唯一性,所以添加相同值时会被忽略。返回成功添加元素的数量。

    删除元素

     srem 

    语法:SREM key member [member ...] 删除集合中一个或多个元素,返回成功删除的个数。

    获取全部元素

    smembers

    语法:SMEMBERS key ,返回集合全部元素 

     值是否存在

    sismember

     语法:SISMEMBER key member ,如果存在返回1,不存在返回0 

     差运算

    sdiff

    语法:SDIFF key [key ...] ,例如:集合A和集合B,差集表示A-B,在A里有的元素B里没有,返回差集合;多个集合(A-B)-C

    交运算

    siniter 

    语法:SINTER key [key ...],返回交集集合,每个集合都有的元素

    并运算

    sunion

    语法:SUNION key [key ...],返回并集集合,所有集合的元素

    集合元素个数

     scard

     语法:SCARD key ,返回集合元素个数

    集合运算后存储结果

    sdiffstroe

     语法:SDIFFSTROE destination key [key ...] ,差运算并存储到destination新集合中。 SINTERSTROE destination key [key ...],交运算并存储到destination新集合中。 SUNIONSTROE destination key [key ...],并运算并存储到destination新集合中

    随机获取元素

    srandmember

    语法SRANDMEMBER key [count],根据count不同有不同结果,count大于元素总数时返回全部元素。count>0 ,返回集合中count不重复的元素。count<0,返回集合中count的绝对值个元素,但元素可能会重复

    弹出元素

     spop  

    语法:SPOP key [count] ,因为集合是无序的,所以spop会随机弹出一个元素

    五:有序集合类型zset           

    添加集合元素

    zadd

    语法:ZADD key [NX|XX] [CH] [INCR] score member [score member ...],不存在添加,存在更新。

    获取元素分数

    zscore

    语法:ZSCORE key member ,返回元素成员的score 分数

    元素小到大

    zrange

    语法:ZRANGE key start top [WITHSCORES] ,参考LRANGE ,加上withscores 返回带元素,即元素,分数

    当分数一样时,按元素排序

    元素大到小

    zrevrange

    语法:ZREVRANGE key start [WITHSCORES] ,与zrange区别在于zrevrange是从大到小排序

    指定分数范围元素

    zrangebyscore

     语法:ZRANGEBYSCORE key min max [WITHSCORE] [LIMIT offest count]。返回从小到大的在minmax之间的元素,( 符号表示不包含,例如:80-100(返回带分数

     limit offest count 向左偏移offest个元素,并获取前count个元素

    指定分数范围元素

    zrevrangescore

    语法:ZREVRANGEBYSCORE key max  min [WITHSCORE] [LIMIT offest count]zrangebyscore类似,只不过该命令是从大到小排序的

    增加分数

    zincrby

      语法:ZINCRBY key increment member ,注意是增加分数,返回增加后的分数;如果成员不存在,则添加一个为0的成员。

    Jedis jedis=new Jedis();

    Jedis.expire(key,time);//在指定的key设置超时时间

    Jedis.exists(key);//判断某个key是否存在

    Jedis.del(key);//删除某个key

  • 相关阅读:
    【iOS系列】-iOS的多线程解析
    【iOS系列】-单例模式的实现
    Mac下Apache+MySQL+PHP安装
    【ios系列】-Quartz 2D常用方法介绍
    【ios系列】-数据储存
    【iOS系列】-文件管理
    我是怎么用FullCalendar记录我的2013年(辞职N次,面试2N次)的,它还兼容IE6
    2014年我去哪里过年?
    unity3d Human skin real time rendering plus 真实模拟人皮实时渲染 plus篇
    Unity3d shader之次表面散射(Subsurface Scattering)
  • 原文地址:https://www.cnblogs.com/zhaosq/p/9804606.html
Copyright © 2011-2022 走看看