【Redis】Hash哈希类型基本使用

2022-02-24 09:58:31 浏览数 (1)

1. 简介

  • Redis hash 是一个键值对集合。
  • Redis hash是一个string类型的fieldvalue的映射表,hash特别适合用于存储对象。类似Java里面的Map<String,Object> 在这里插入图片描述在这里插入图片描述
  • 用户ID为查找的key,存储的value用户对象包含姓名,年龄,生日等信息,如果用普通的key/value结构来存储
  • 主要有以下2种存储方式:
  • 每次修改用户的某个属性需要,先反序列化改好后再序列化回去。开销较大。 在这里插入图片描述在这里插入图片描述
  • 用户ID数据冗余 在这里插入图片描述在这里插入图片描述
在这里插入图片描述在这里插入图片描述
  • 通过 key(用户ID) field(属性标签) 就可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并发修改控制的问题 在这里插入图片描述在这里插入图片描述

2. 常用命令

  • <key>集合中的 <field>键赋值<value>
代码语言:sql复制
hset <key> <field> <value>
  • <key1>集合<field>取出 value
代码语言:sql复制
hget <key1> <field>
在这里插入图片描述在这里插入图片描述
  • 批量设置hash的值
代码语言:sql复制
hmset <key1> <field1> <value1> <field2> <value2>...
在这里插入图片描述在这里插入图片描述
  • 查看哈希表 key 中,给定域 field 是否存在
代码语言:sql复制
hexists <key1> <field>
在这里插入图片描述在这里插入图片描述
  • 列出该hash集合的所有field
代码语言:sql复制
hkeys <key>
  • 列出该hash集合的所有valuehvals <key>
在这里插入图片描述在这里插入图片描述
  • 为哈希表 key 中的域 field 的值加上增量
代码语言:sql复制
hincrby <key> <field> <increment>
  • 将哈希表 key 中的域 field 的值设置为 value ,当且仅当域 field 不存在
代码语言:sql复制
hsetnx <key> <field> <value>
在这里插入图片描述在这里插入图片描述

3. Hash类型的数据结构

  • Hash类型对应的数据结构是两种:ziplist(压缩列表),hashtable(哈希表)。当field-value长度较短且个数较少时,使用ziplist,否则使用hashtable

0 人点赞