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)

    #对应的集合中添加元素

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

原文地址:https://www.cnblogs.com/venvive/p/11708232.html

时间: 2024-07-28 20:51:06

redis缓存数据库Hash,list,set操作的相关文章

Redis缓存数据库服务器

Redis缓存数据库服务器Redis是一个开源的科技与内存也可持久化的日志型.Key-Value数据库Redis的存储分为内存存储.磁盘存储和Log文件三部分,配置文件中有三个参数对其进行配置. 优势:和Mecached相比,它更加安全也支持存储的value类型相对更多.Redis会周期性的把更新的数据写入磁盘或者把修改操作写入追加的记录文件,并且在此基础上实现了master-slave(主从)同步 /var/log/redis_6379.log 日志文件/var/lib/redis/6379

Python基础16 - RabbitMQ队列、Redis缓存数据库

@@@文章内容参照老男孩教育 Alex金角大王,武Sir银角大王@@@ RabbitMQ队列 下载安装http://www.rabbitmq.com/install-windows.html RabbitMQ 教程官网:http://www.rabbitmq.com/getstarted.html RabbitMQ:erlang语言 开发的. Python中连接RabbitMQ的模块:pika .Celery(分布式任务队列) .haigha可以维护很多的队列 几个概念说明: Broker:简单

快速搭建Redis缓存数据库

之前一篇随笔——Redis安装及主从配置已经详细的介绍过Redis的安装于配置.本文要讲的是如何在已经安装过Redis的机器上快速的创建出一个新的Redis缓存数据库. 一.环境介绍 1) Linux版本:Red Hat Enterprise Linux Server release 6.1 (Santiago) 2) Redis版本:Redis 2.6.16  64 bit 3) Redis安装路径:/usr/local/webserver/redis 二.安装步骤 1) 将/usr/loca

Python操作Redis缓存数据库

首先我们需要使用到一个redis库,使用之前先安装一下,使用pip进行安装: pip install redis 安装好了redis库之后,我们只需使用import redis导入即可使用了,大部分都是通过这两个步骤使用的:接下来讲解如何操作Redis数据库,介绍一下Redis的五大数据类型:分别是字符串类型string.列表类型list.集合类型set.哈希类型hash.有序集合类型 sorted set 开启数据库 要注意我们操作之前需要先开启Redis数据库,如何安装Redis数据库(该步

redis缓存数据库

缓存数据库介绍 redis操作 缓存数据库介绍 NoSQL(NoSQL = Not Only SQL ),意即“不仅仅是SQL”,泛指非关系型的数据库,随着互联网web2.0网站的兴起,传统的关系数据库在应付web2.0网站,特别是超大规模和高并发的SNS类型的web2.0纯动态网站已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展.NoSQL数据库的产生就是为了解决大规模数据集合多重数据种类带来的挑战,尤其是大数据应用难题. NoSQL数据库的

Redis缓存数据库详解

Redis最为常用的数据类型主要有以下五种: 1)String 2)Hash 3)List 4)Set 5)Sorted set 在具体描述这几种数据类型之前,我们先通过一张图了解下Redis内部内存管理中是如何描述这些不同数据类型的: 首先Redis内部使用一个redisObject对象来表示所有的key和value,redisObject最主要的信息如上图所示:type代表一个value对象具体是何种数据类型,encoding是不同数据类型在redis内部的存储方式,比如:type=stri

LAMP+Redis缓存数据库整合

LAMP在企业生产环境中,除了将MYSQL单独部署在其他服务器.由于MYSQL数据库压力会很大,还会对MYSQL实现主从复制及读写分离,同时会对PHP网站进行调优,通常PHP的优化手段包括:PHP代码本身优化.PHP配置文件优化.为PHP添加缓存模块,将PHP网站数据存入缓存等. 为了减轻MYSQL数据库的压力,这时就用到了Redis缓存数据库服务, LAMP+Redis工作机制:用户通过浏览器访问LAMP网站,并以用户名和密码登录到网站,默认Redis缓存中没有该用户名和密码对应列表,PHP程

Spring AOP + Redis缓存数据库查询

应用场景 我们希望能够将数据库查询结果缓存到Redis中,这样在第二次做同样的查询时便可以直接从redis取结果,从而减少数据库读写次数. 需要解决的问题 操作缓存的代码写在哪?必须要做到与业务逻辑代码完全分离. 如何避免脏读? 从缓存中读出的数据必须与数据库中的数据一致. 如何为一个数据库查询结果生成一个唯一的标识?即通过该标识(Redis中为Key),能唯一确定一个查询结果,同一个查询结果,一定能映射到同一个key.只有这样才能保证缓存内容的正确性 如何序列化查询结果?查询结果可能是单个实体

Redis缓存数据库的安装与配置(1)

1.安装 tarxf redis-3.2.5.tar.gz cd redis-3.2.5 make mkdir -p /usr/local/redis/bin src目录下这些文件作用如下 redis-server:Redis服务器的daemon启动程序 redis-cli:Redis命令行操作工具.你也可以用telnet根据其纯文本协议来操作 redis-benchmark:Redis性能测试工具,测试Redis在你的系统及你的配置下的读写性能. cp   redis-benchmark  r