zoukankan      html  css  js  c++  java
  • redis缓存数据库Hash,list,set操作

    Hash操作

    hash表现形式上有些像python中的dict,可以存储一组关联性较强的数据,redis中Hash在内存中的存储格式如下图:

    1、hset(name,key,value)

        #name对应的hash中设置一个键值对(不存在,则创建;否则,修改)
        #参数:
        #name,redis的name
        #key,name对应的hash中的key
        #vale,name对应的Hash中的value
        #如:
        127.0.0.1:6379> hset fle1 k1 2
        (integer) 1
    

    2、hmset(name,mapping)

        #在name对应的Hash中批量设置键值对
        #参数:
            #name,redis的name
            #mapping,字典,如:{'k1':'v1','k2':'v2'}
            
        #如:
        127.0.0.1:6379> hmset fle2 k1 3 k2 4 k3 5
            OK
    

    3、hget(name,key)

        #在name对应的hash中获取多个key的值
        #如:
        hget fle2 k1
        "3"
    

    4、hmget(name,keys,*args)

        #在name对应的hash中获取多个key的值
        
        #参数:
            #name:redis对应的name
            #keys,要获取key集合
            #*args,要获取的Key
        #如:
        hmget fle2 k1 k2 k3
        1) "3"
        2) "4"
        3) "5"
    

    5、hgetall(name)

        #获取name对应hash的所有键值
    

    6、hlen(name)

        #获取name对应的hash中键值对的个数
        127.0.0.1:6379> hlen fle2
        (integer) 3
    

    7、hkeys(name)

        #获取name对应的hash中所有的key的值
        如:
            127.0.0.1:6379> hkeys fle2
                1) "k1"
                2) "k2"
                3) "k3"
    

    8、hvals(name)

        #获取name对应的hash中所有的value的值
        如:
        127.0.0.1:6379> hvals fle2
        1) "3"
        2) "4"
        3) "5"
    

    9、hexists(name,key)

        #检查name对应的hash是否存在当前传入的key
        #存在返回1,不存在返回0
        如:
            127.0.0.1:6379> hexists fle2 k2
            (integer) 1
            127.0.0.1:6379> hexists fle2 y
            (integer) 0
    

    10、hdel(name,*keys)

        #将name对应的hash中指定key的键值对删除
        如:
            127.0.0.1:6379> hdel fle2 k2
            (integer) 1
            127.0.0.1:6379> hexists fle2 k2
            (integer) 0
    

    11、hincrby(name,key,amount=1)

        #自增name对应的值,当name不存在时,则创建name=amount,否则,则自增
        如:
            27.0.0.1:6379> incrbyfloat k2 1
            "1"
            127.0.0.1:6379> 
            127.0.0.1:6379> incrbyfloat k2 1
            "2"
            127.0.0.1:6379> incrbyfloat k2 1
            "3"
    

    12、hincrbyfloat(name, key, amount=1.0)

        #自增name对应的hash中的指定key的值,不存在则创建key=amount
        #参数:
            #name,redis中的name
            #key,hash对应的key
            #amount,自增数(浮点数)
        #自增name对应的hash中的指定key的值,不存在则创建key=amount        
    

    13、hscan_iter(name,match=None,count=None)

        #利用yield封装hscan创建生成器,实现分批去redis中获取数据
        
        #参数:
            #match,匹配指定key,默认None表示所有的key
            #count,每次分片最少获取个数,默认None表示采用Redis的默认分片个数
    

    list操作

    list操作,redis中的List在内存中按照一个name对应一个List来存储,如图:

    1、lpush(name,values)

        #在name对应的list中添加元素,每个新的元素都添加到列表的最左端
        #如:
        lpush bb 1 2 3 4
        (integer) 4
        #保存顺序:4 3 2 1
        #扩展:
            #rpush(name,values)表示从右向左操作
    

    2、lpushx(name,value)

        #在name对应的list中添加元素,只有name已经存在时,值添加到列表的最左边
        #更多:
            #rpushx(name,value)表示从右向左操作
        #如:
        127.0.0.1:6379> lpushx bb 5
        (integer) 5
    
    

    3、llen(name)

        #name对应的list元素个数
    

    4、linsert(name,where,refvalue,value)

        #在name对应 的列表的某个值前或后插入一个新值
        #参数:
            #name,redis的name
            #where,BEFOR或AFTER
            #refvalue,标杆值,即:在它前后插入数据
            #value,要插入的数据
            
        #如:
            127.0.0.1:6379> linsert bb before 5 8
            (integer) 6
    
    

    5、lset(name,index,value)

        #name对应的List中的某一个索引位置重新赋值
        
        #参数:
            #name,redis的name
            #index,list的索引位置
            #value,要设置的值
        #如:
            27.0.0.1:6379> lset bb 3 90
            OK
    

    6、lrem(name,value,num)

        #在name对应的list中删除指定的值
        #参数:
            #name,redis的name
            #value,要删除的值
            #num,num=0,删除列表中所有的指定值;
            #num=2,从前到后,删除2个
            #num=-2,从后向前,删除2个
    

    7、lpop(name)

        #在name对应的列表左侧获取第一个元素并在列表中移除,返回值则是第一个元素
        #更多:
            #rpop(name)表示从右向左操作
    

    8、lindex(name,index)

        在name对应的列表中根据索引获取列表元素
    

    9、lrange(name,start,end)

        #在name对应的列表分片获取数据
        #参数:
            #name,redis的name
            #start,索引的起始位置
            #end,索引结束位置
    

    10、ltrim(name,start,end)

        #在name对应的列表中移除没有在start-end索引之间的值
        #参数:
            #name,redis的name
            #start,索引的起始位置
            #end,索引结束位置
            
    

    11、rpoplpush(src, dst)

        # 从一个列表取出最右边的元素,同时将其添加至另一个列表的最左边
        # 参数:
        # src,要取数据的列表的name
        # dst,要添加数据的列表的name
    

    12、blpop(keys, timeout)

        # 将多个列表排列,按照从左到右去pop对应列表的元素
     
    # 参数:
        # keys,redis的name的集合
        # timeout,超时时间,当元素所有列表的元素获取完之后,阻塞等待列表内有数据的时间(秒), 0 表示永远阻塞
     
    # 更多:
        # r.brpop(keys, timeout),从右向左获取数据
    

    13、brpoplpush(src, dst, timeout=0)

        # 从一个列表的右侧移除一个元素并将其添加到另一个列表的左侧
     
    # 参数:
        # src,取出并要移除元素的列表对应的name
        # dst,要插入元素的列表对应的name
        # timeout,当src对应的列表中没有数据时,阻塞等待其有数据的超时时间(秒),0 表示永远阻塞
    

    set集合

    set操作,set集合就是不允许重复的列表

    #### 1、sadd(name,values) ```python #对应的集合中添加元素 ```

    https://www.cnblogs.com/alex3714/articles/6217453.html

  • 相关阅读:
    python 小数和百分数之间的转换
    Pandas datetime常用属性
    Pandas 时间处理 获取数组中某月的数据
    Pandas如何将两个Series对象进行与运算
    【数据结构与算法】数组的增删改查
    【效率为王】超详细 Hexo + Github Pages 博客搭建教程
    大牛们都是怎么玩 Manjora 的
    利用 Halo 从 0 到 1 搭建属于自己的博客
    十分钟入门 Markdown 写作
    当前知识水平下的问题复杂度分类
  • 原文地址:https://www.cnblogs.com/venvive/p/11708232.html
Copyright © 2011-2022 走看看