• redis学习笔记(5)hash类型


    1、概述

    Redis hash 是一个键值对集合。

    Redis hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。类似 Java 里面的 Map<String,Object>。

    用户 ID 为查找的 key,存储的 value 用户对象包含姓名,年龄,生日等信息,如果用普通的 key/value 结构来存储,主要有以下 2 种存储方式:

                                           

    方法一:每次修改用户的某个属性需要,先反序列化改好后再序列化回去。开销较大。

    方法二:用户 ID 数据冗余。

    通过 key (用户 ID) + field (属性标签) 就可以操作对应属性数据了,既不需要重复存储数据,也不会带来序列化和并发修改控制的问题。

    2、相关操作

    • hset key field value----------将key的hash表中的字段field设值为value(由field和关联的value组成的map),字段不存在则生成,存在则覆盖(相当于更新)
    • hmset key field1key field1value [field2key field2value …]----------同时为key的hash表设置多个字段与值
    • hsetnx key field value--------------只有字段field不存在是,将key的hash表中添加字段field并设值为value
    • hgetall key---------获取key中所有的字段和值
    • hexists key field-------------key中是否存在指定的字段返回integer,1-存在,0-不存在
    • hget key field---------------获取key中指定字段的值
    • hmget key field1 [field2…]----------------获取所有给定字段的值
    • hkeys key-------------获取key中的所有字段
    • hlen key-----------key的字段数量,返回integer
    • hvals key---------------获取hash表中所有值
    • hdel key field1 [field2]-------------删除一个或多个hash字段

    3、数据结构

    Hash 类型对应的数据结构是两种:ziplist(压缩列表),hashtable(哈希表)。

    当 field-value 长度较短且个数较少时,使用 ziplist,否则使用 hashtable。

  • 相关阅读:
    查看java程序中对象占用空间大小
    elasticsearch的基本了解
    kafka命令及启动
    屠龙之路_大杀技之倚天屠龙_TenthDay
    屠龙之路_坚持就是胜利_NinthDay
    屠龙之路_狭路相逢勇者胜_EighthDay
    屠龙之路_任生活如何虐你,屠龙之路还得继续_SeventhDay
    屠龙之路_假期罢工和公主私奔_SixthDay
    屠龙之路_击败DB小boss_FifthDay
    屠龙之路_转角遇到服务器大魔王_FourthDay
  • 原文地址:https://www.cnblogs.com/mango1997/p/16210433.html
Copyright © 2020-2023  润新知