zoukankan      html  css  js  c++  java
  • redis的hash, list, set类型相关命令

    hash相关命令:

    1. hset
    HSET key field value
    将哈希表key中的域field的值设为value。如果key不存在,一个新的哈希表被创建并进行hset操作。如果域field已经存在于哈希表中,旧值将被覆盖。
    2. hget
    HGET key field
    返回哈希表key中指定的field的值。
    3. hsetnx
    HSETNX key field value
    将哈希表key中的域field的值设置为value,当且仅当域field不存在。若域field已经存在,该操作无效。如果key不存在,一个新哈希表被创建并执行hsetnx命令。
    4. hmset
    HMSET key field value [field value ...]
    同时将多个field - value(域-值)对设置到哈希表key中。此命令会覆盖哈希表中已存在的域。如果key不存在,一个空哈希表被创建并执行hmset操作。
    5. hmget
    HMGET key field [field ...]
    返回哈希表key中,一个或多个给定域的值。如果给定的域不存在于哈希表,那么返回一个nil值。因为不存在的key被当作一个空哈希表来处理,所以对一个不存在的key进行hmget操作将返回一个只带有nil值的表。
    6. hgetall
    HGETALL key
    返回哈希表key中,所有的域和值。在返回值里,紧跟每个域名(field name)之后是域的值(value),所以返回值的长度是哈希表大小的两倍。
    7. hdel
    HDEL key field [field ...]
    删除哈希表key中的一个或多个指定域,不存在的域将被忽略。
    8. hlen
    HLEN key
    返回哈希表key对应的field的数量。
    9. hexists
    HEXISTS key field
    查看哈希表key中,给定域field是否存在。
    10. hkeys
    HKEYS key
    获得哈希表中key对应的所有field。
    11. hvals
    HVALS key
    获得哈希表中key对应的所有values。
    12. hincrby
    为哈希表key中的域field的值加上增量increment。增量也可以为负数,相当于对给定域进行减法操作。如果key不存在,一个新的哈希表被创建并执行hincrby命令。如果域field不存在,那么在执行命令前,域的值被初始化为0。对一个储存字符串值的域field执行hincrby命令将造成一个错误。本操作的值限制在64位(bit)有符号数字表示之内。

    redis list 类型:

    push pop 队列先进先出 栈先进后出 list 既可以作为栈又可以作为队列

    List 是一个链表结构,主要功能是push,pop,获取一个范围的所有值等等,操作中key理解为链表的名字

    In [91]: r.lpush('url', 'xiaorui.cc')
    Out[91]: 1L
    In [92]: r.lpush('url', '163.com')
    Out[92]: 2L
    In [93]: r.lpush('url', 'sina.com')
    Out[93]: 3L
    In [94]: r.lpush('url', 'qq.com')
    Out[94]: 4L
    In [95]: r.lpush('url', 'letv.com')
    Out[95]: 5L
    In [96]: r.lrange('url', 0,-1) 
    Out[96]: ['letv.com', 'qq.com', 'sina.com', '163.com', 'xiaorui.cc']
    In [97]: r.rpop("url")         
    Out[97]: 'xiaorui.cc'
    In [98]: r.rpop("url")
    Out[98]: '163.com'
    In [99]: r.rpop("url")
    Out[99]: 'sina.com'
    In [100]: r.rpop("url")
    Out[100]: 'qq.com'
    In [101]: r.rpop("url")
    Out[101]: 'letv.com'

    redis的list的详细点的用法:

    1  lpush  从list 头部压入一个元素   先进后出
        lpush mylist "word"
        lpush mylist "ehll"
        lrange mylist 0 -1    显示  ehll    word
    2  lrange mylist 0 -1    0代表从头部  1 从尾部
    3  rpush  从尾部压入一个元素    先进先出
        rpush list2  zhang
        rpush list2   san
        lrange list2  0 -1
         return  zhang san
    4  linsert从中间压入一个元素
        lpush mylist3  "world"
        在  one   two 直接压入three
        lpush list3 one
        lpush list3 two
        linsert list3 before one three
    5  lset 给某个元素赋值
        lpush list3 one
        lpush list3 two
        lset list3 1 three
       two  的值被改变成three
    6 lrem  从key 对应list中删除n个和value相同的元素   (n<0从尾部删除,n=0全部删除)
          remove
       lrem  list6 2 one      删除2个和one一样值元素
    7 ltrim  保留指定key范围内的数据
       1 2 3 4
       ltrim   list8 1 -1  保留的元素范围,其余的都删除
    8  lpop   从list 头部删除一个元素,并返回删除的元素
        lpop mylist
    9  rpop  从list 尾部删除一个元素,并返回删除的元素
        rpop  mylist
    10  rpoplpush  从尾部删除一个元素并从头部添加一个元素
         rpoplpush   mylist1   mylist2  把mylist1 元素删除 添加到mylist2中
    11 lindex 返回名称为key的list 中index 位置的元素
         lindex mylist 0
         lindex mylist 1
    12  llen 返回链表中的元素个数
          llen  mylist

    对于 redis set的使用:

    sadd(key, member):向名称为key的set中添加元素member
    srem(key, member) :删除名称为key的set中的元素member
    spop(key) :随机返回并删除名称为key的set中一个元素
    smove(srckey, dstkey, member) :移到集合元素
    scard(key) :返回名称为key的set的基数
    sismember(key, member) :member是否是名称为key的set的元素
    sinter(key1, key2,…key N) :求交集
    sinterstore(dstkey, (keys)) :求交集并将交集保存到dstkey的集合
    sunion(key1, (keys)) :求并集
    sunionstore(dstkey, (keys)) :求并集并将并集保存到dstkey的集合
    sdiff(key1, (keys)) :求差集
    sdiffstore(dstkey, (keys)) :求差集并将差集保存到dstkey的集合
    smembers(key) :返回名称为key的set的所有元素
    srandmember(key) :随机返回名称为key的set的一个元素
  • 相关阅读:
    after() 和 remove() 实现替换
    jquery not() 方法
    jQuery filter() , end()
    jquery 拓展函数集
    window onload || jquery $()
    java jdk environment variables
    mysql 64 zip download
    闭包初探
    hdu 1195 Open the Lock (BFS)
    poj 1743 Musical Theme (后缀数组+二分法)
  • 原文地址:https://www.cnblogs.com/imxiu/p/3504994.html
Copyright © 2011-2022 走看看