Redis-带你深入学习数据类型Hash【面试重点】

目录

1、基础知识

2、相关命令

2.1、hset、hget

2.2、hexists

2.3、hdel

2.4、hkeys、hvals、hgetall

2.5、hmget、hmset

2.6、hlen

2.7、hsetNX

2.8、Hincrby、Hincrbyfloat

3、应用场景-缓存

4、缓存方式对比


1、基础知识

        redis中存储数据本身就是以键值对的形式,而这里的hash类型,指的是redis的key value中的value是以键值对的形式存储的,也就是说,键值对中的值也是键值对~


2、相关命令

2.1、hset、hget

hset:设置hash中指定字段的值

  • 语法:hset key field value [field value ...]
  • 如果没有key,则会设置一个key再存入field value;否则直接在对应的key中存入field value
  • field其实和key一样,就是键值对中的键,为了区分开来,所以用field表示
  • 返回值:成功插入的field value值的对数
  • hset支持一次在一个key中存入多组field value
  • 时间复杂度O(1)

举例:

hget:取出key中指定字段的值

  • 语法:hget key field
  • 返回值:对应value值,无则返回 nil
  • 时间复杂度O(1),k组filed value则为O(k)

举例:

2.2、hexists

  • hexists:判断是否存在指定的字段
  • 语法:hexists key filed
  • 返回值:存在返回1 ;不存在返回0
  • 时间复杂度O(1)

举例:

2.3、hdel

  • hdel:删除hash中指定的字段
  • 语法:hdel key filed [field ...]
  • 返回值:成功删除的字段个数
  • 时间复杂度O(1)---O(k)
  • 与命令del的区别:del删除的是key;hdel删除的是field

举例:

2.4、hkeys、hvals、hgetall

 hkeys:取出key中的所有field

  • 语法:hkeys key
  • 返回值:该key下的所有field
  • 时间复杂度O(1)
  • 该操作存在风险:可能一个key下有很多个field value的键值,此方法就可能会造成一个方法执行时间过长~

举例:

hvals:取出key中的所有value

  • 语法:hvals key
  • 返回值:该key下的所有value
  • 时间复杂度O(1)
  • 风险同上

举例:

 hgetall:取出key下的所有field和value

  • 语法:hgetall key
  • 返回值:该key下的所有field和value
  • 时间复杂度O(1)
  • 风险同上

举例:

2.5、hmget、hmset

hmget:一次获取hash中多个字段的值

  • 语法:hmget key field  [field...]
  • 返回值:对应的value值,无则返回nil
  • 时间复杂度O(1)---O(k)

举例:

hmset:一次存入多个字段,几乎和hset一样,因此这个命令很少使用~

2.6、hlen

  • hlen:获取hash中的对应key中所有的字段个数
  • 语法:hlen key
  • 时间复杂度O(1)
  • 返回值:字段个数

举例:

2.7、hsetNX

  • hsetNX:在字段不存在时,才能成功设置hash中的字段的值
  • 语法:hsetNX key field value
  • 时间复杂度O(1)
  • 返回值:设置成返回1;失败返回0

 举例:

2.8、Hincrby、Hincrbyfloat

Hincrby:将hash中字段对应的数值添加指定的值

  • 语法:Hincrby key field increment
  • 时间复杂度O(1)
  • 返回值:字段value变化后的值

举例:

Hincrbyfloat:将hash中字段对应的数值添加指定的浮点数

  • 语法:hincrbyfloat key field increment
  • 时间复杂度O(1)
  • 返回值:字段value变化后的值

举例:


3、应用场景-缓存

        在上一片博客中,提到string类型的应用场景为缓存,hash也可以是吗?对的,这两种方法有各自的优缺点,具体使用按照具体的业务场景来选择就好,相对来说,9存储结构化的数据,使用hash其实是更加适合滴~【结构化数据-->类似于数据库表这种的】

        使用hash存储结构化数据举例:

        倘若使用string来存储,需要利用到json这样的数据格式,只不过在修改一个key中指定的field对应value值会比较麻烦,需要我们先取出json,然后解析出内部的value值,做出修改后,再合成json,后再存入key中指定的field处~


4、缓存方式对比

原生字符串类型---使用字符串类型,每个属性一个键

  • 优点:实现简单,针对个别属性变更更灵活
  • 缺点:占用过多的键,内存占用量较大,用户信息在redis中分布比较分散,缺少内聚性-几乎不使用

序列化字符串类型,例:JSON格式

  •  优点:针对总是以整体为操作的信息比较合适,编程也简单;内存使用效率较高
  • 缺点:本身序列化和反序列化需要一定开销,如果总是操作个别属性非常不灵活

哈希

  •  优点:简单、直观、灵活;尤其针对信息的局部变更或者获取操作
  • 缺点:需要控制哈希在ziplist和hashtable两种内部编码的转换,可能会造成内存较大的消耗

 好啦,我们下期见咯~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

龙洋静

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值