Redis常用的5种数据类型

Redis数据类型(5种常用)

  • 字符串类型 String String
  • 列表类型 list LinkedList
  • 散列类型 hash HashMap
  • 集合类型 set HashSet
  • 有序集合类型 sorted_set TreeSet

redis数据存储格式

  • redis自身是一个Map,其中所有的数据都是采用key:value的形式存储
  • 数据类型指的是存储的数据的类型,是value部分的类型,key部分永远是字符串

string类型

  • 存储的数据:单个数据,最简单的数据存储类型
  • 存储数据的格式:一个存储空间保存一个数据
  • 存储内容:通常使用字符串,如果字符串以整数的形式展示,可以作为数字操作使用
基本操作

添加、修改数据

set key value

获取数据

get key

删除数据

del key

添加、修改多个数据

mset key1 value1 key2 value2 ...

获取数据

mget key1 key2 ...

获取数据字符个数(字符串长度)

strlen key

追加信息到原始后部(如果存在就追加,否则新建)

append key value

一次操作需要发送时间 操作时间 返回时间

如果有3次set set操作需要3次发送3次返回3次操作

mset只需要1次发送1次返回3次操作

但是1亿条 一次性发又会阻塞

具体怎么来对应具体情况

string类型数据的扩展操作

业务场景

大型企业级应用中,分表操作是基本操作,使用多张表存储同类型数据,但是对应的主键id必须保证统一性,不能重复。Orade 数据库具有sequence设定,可以解决该问题,但是MySQL数据库并不具有类似的机制,那么如何解决?

解决方案

  • 设置数值数据增加指定范围的值
incr key
incrby key increment
incrbyfloat key increment
  • 设置数值数据减少指定范围的值
decr key
decrby key increment

string作为数值操作

  • string在redis内部存储默认就是一个字符串, 当遇到增减类操作incr, decr时会转成数值型进行计算。
  • redis所有的操作都是原子性的, 采用单线程处理所有业务,命令是一个-个执行的,因此无需考虑并发带来的数据影响。
  • 注意:按数值进行操作的数据, 如果原始数据不能转成数值,或超越了redis数值上限范围,将报错。9223372036854775807 (java中long型数据最 大值,Long.MAX _VALUE)
tip1
  • redis用于控制数据库表主键id,为数据库表主键提供生成策略,保障数据库表的主键唯一性
  • 此方案适用于所有数据库,且支持数据库集群

业务场景

“最强女生”启动海选投票,只能通过微信投票,每个微信号每4小时只能投1票。
电商商家开启热门商品推荐,热门商品不能一直处于热门 期,每种商品热门期维持3天,3天后自动取消热门。
新闻网站会出现热点新闻,热点新闻最大的特征是时效性,如何自动控制热点新闻的时效性。

解决方案

  • 设置数据具有指定的生命周期
setex key seconds value
psetex key milliseconds value

如果用了set 就会把 setex覆盖

tip2
  • redis控制数据的生命周期,通过数据是否失效控制业务行为,适用于所有具有时效性限定控制的操作
string类型数据操作的注意事项
  • 数据操作不成功的反馈与正常操作之间的差异
    1. 表示运行结果是否成功
      • (integer)0 → false 失败
      • (integer)1 → true 成功
    2. 表示运行结果值
      • (integer)3 → 3
  • 数据未获取到 (nil)等同于null
  • 数据最大存储量 512MB

业务场景

主页高频访问信息显示控制,例如新浪微博大V主页显示粉丝数(热点数据)

解决方案

  • 在redis中为大V用户设定用户信息,以用户主键和属性值为key,后台设备定时刷新策略即可

    eg: user:id:3506728370:fans → 12210947

    eg: user:id:3506728370:blogs → 6165

set user:id:00789:fans 1234567
set user:id:00789:blogs 789
  • 在redis中以json格式存储大V用户信息,定时刷新(也可以使用hash类型)
set user:id:00789 {id:00789,blogs:789,fans:123}
tip3
  • redis应用于各种结构型和非结构型高热度数据访问加速
key的设置约定
  • 数据库中的热点数据key命名惯例
表名:主键名:主键值:字段名:
eg1order:id:2934512name
eg2order:id:2934512type
eg3order:id:2934512title

hash类型

key : (field:value)

  • 新的存储需求:对一系列存储的数据进行编组,方便管理,典型应用存储对象信息
  • 需要的存储结构:一个存储空间保存多个键值对数据
Redis存储空间
hash存储空间
keyfield1value1
field2value2
field3value3

hash存储结构优化

  • 如果field数量较少,存储结构优化为 类数组 结构
  • 如果field数量较少,存储结构优化为 HashMap 结构
基本操作

添加、修改数据

hset key field value

获取数据

hget key field
hgetall key

删除数据

hdel key field1 [field2]

添加、修改多个数据

hmset key1 field1 value1 field2 value2 ...

获取数据

hmset key1 field1 field2

获取哈希表中字段的数量

hlen key

获取哈希表是否存在指定的字段

hexists key field
hash类型数据的扩展操作
  • 获取哈希表中所有的字段名或字段值
hkeys key
hvals key
  • 设置指定字段的数值数据增加指定范围的值
hincrby key field increment
hincrbyfloat key field increment
hash类型数据操作的注意事项
  • hash类型下的value只能存储字符串,不允许存储其他数据类型,不存在嵌套现象。如果数据未获取到,对应的值为(nil)
  • 每个hash可以存储2^32 -1个键值对
  • hash类型十分贴近对象的数据存储形式,并且可以灵活添加删除对象属性。但hash设计初衷不是为了存储大量对象而设计的,切记不可滥用,更不可以将hash作为对象列表使用
  • hgetall可以获取全部属性,如果内部field过多,遍历整体效率就会很低,有可能成为数据访问瓶颈

string存储对象(json)与hash存储对象

string更讲究整体 hash更适合更新

list类型

  • 数据存储需求:存储多个数据,并对数据进入存储空间的顺序进行区分
  • 需要的存储结构:一个存储空间保存多个数据,且通过数据可以体现进入顺序
  • list类型:保存多个数据,底层使用双向链表存储结构实现
    在这里插入图片描述
基本操作

添加、修改数据

lpush key value1 [value2] ...
rpush key value1 [value2] ...

获取数据

lrange key start stop(-1表示全部查) 
lindex key index
llen key

获取并移除数据

lpop key
rpop key
list类型数据的扩展操作
  • 规定时间内获取并移除数据(b指block)为空的时候会阻塞等待 可以在若干个列表里等
blpop key1 [key2] timeout
brpop key1 [key2] timeout
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值