一. 哈希对象概述

  Redis hash对象是一个string类型的field和value的映射表,hash特别适合用于存储对象。作为哈希对象的编码,有二种一是ziplist编码, 二是hashtable编码。在不同情况下编码是可以转换的。在Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿)。

  1.1 ziplist编码

    如果哈希对象是以ziplist编码的压缩列表作为底层实现,那么每当有新的键值对要加入到哈希对象时,程序会先将保存了键的压缩列表节点推入到压缩列表表尾,然后再保存了值的压缩列表节点推入到压缩列表表尾。因此:

    (1)保存了同一个键值对的两个节点总是紧挨在一起,保存键的节点在前,保存值的节点在后。

    (2)先添加到哈希对象中的键值对被放在压缩列表的表头方向,后添加到哈希对象中的键值对会被放在压缩列表的表尾方向。

    例1 下面使用hset命令,创建一个哈希对象名为profile。这个值对象使用ziplist编码。对象所使用的压缩列表底层实现 如下图所示:

  127.0.0.1:> hset profile name "tom"
  (integer)
  127.0.0.1:> hset profile age
  (integer)
  127.0.0.1:> object encoding profile
  "ziplist"

        

  1.2  hashtable编码

    例2 下面还是使用hset命令,创建一个哈希对象名为book。这个值对象使用hashtable编码,因为字符串长度大于64字节,对象所使用字典底层实现要比ziplist编码的压缩列表底层实现结构更为复杂。这里就在再贴ziplist编码的redisobject结构,代码如下所示:

  127.0.0.1:> hset
  book _long_long_long_long_long_long_long_long_long_long_long_long_long_long_long_long_long_long_long_long "content"
  (integer)
  127.0.0.1:> object encoding book
  "hashtable"

  1.3 编码转换

    哈希对象可以同时满足以下两个条件时,哈希对象使用ziplist编码:(1)哈希对象保存的所有键值对的键和值的字符串长度都小于64字节;(2) 哈希对象保存的键值对数量小于512个。 当不能满足这两个条件的哈希对象需要使用hashtable编码。

    对于上面编码转换的两个条件,上限值是可以修改的,具体看配置文件中关于hash-max-ziplist-value选项和hash-max-ziplist-entries选项说明。

  127.0.0.1:> config get hash-max-ziplist-value
  ) "hash-max-ziplist-value"
  ) ""
  127.0.0.1:> config get hash-max-ziplist-entries
  ) "hash-max-ziplist-entries"
  ) ""

二. 哈希命令实现

 -- Hdel 命令用于删除哈希表 key 中的一个或多个指定字段,不存在的字段将被忽略。返回被成功删除字段的数量,不包括被忽略的字段。
127.0.0.1:> hdel myhash field1 field2
(integer)
127.0.0.1:> hgetall myhash
(empty list or set) --已删除field1 field2 --Hexists 命令用于查看哈希表的指定字段是否存在。
127.0.0.1:> hexists profile field1
(integer)
127.0.0.1:> hset profile field1 "one"
(integer)
127.0.0.1:> hexists profile field1
(integer) --字段field1存在,返回1 -- Hget 命令用于返回哈希表中指定字段的值
127.0.0.1:> hget profile field1
"one" -- Hgetall 命令用于返回哈希表中,所有的字段和值。
127.0.0.1:> hgetall profile
) "field1"
) "one"
) "field2"
) "two" -- Hincrby 命令用于为哈希表中的字段值加上指定增量值。增量也可以为负数,相当于对指定字段进行减法操作。
127.0.0.1:> hset myhash field1
(integer)
127.0.0.1:> hincrby myhash field1
(integer) -- Hincrbyfloat 命令用于为哈希表中的字段值加上指定浮点数增量值。
127.0.0.1:> HSET myhash field 20.50
(integer)
127.0.0.1:> hincrbyfloat myhash field 0.1
20.6" -- Hkeys 命令用于获取哈希表中的所有字段名。
127.0.0.1:> hkeys profile
) "field1"
) "field2" --Hlen 命令用于获取哈希表中字段的数量。
127.0.0.1:> hlen profile
(integer) -- Hmget 命令用于返回哈希表中,一个或多个给定字段的值
127.0.0.1:> hmget profile field1 field2 field
) "one"
) "two"
) (nil) --这个字段不存在 -- Hmset 命令用于同时将多个 field-value (字段-值)对设置到哈希表中
127.0.0.1:> HmSET myhash field1 "foo" field2 "bar"
OK
127.0.0.1:> hgetall myhash
) "field1"
) "foo"
) "field2"
) "bar" -- Hset 命令用于为哈希表中的字段赋值 ,如果字段已经存在于哈希表中,旧值将被覆盖。如果字段是一个新建字段,值设置成功返回 。 如果字段已经存在,旧值被新值覆盖返回 。
127.0.0.1:> hset myhash field1 "three"
(integer) -- 已存在的覆盖值成功,返回0
127.0.0.1:> hgetall myhash
) "field1"
) "three"
) "field2"
) "bar" -- Hsetnx 命令用于为哈希表中不存在的的字段赋值,如果字段已经存在于哈希表中,操作无效。
127.0.0.1:> HSETNX myhash field1 "foo"
(integer)
127.0.0.1:> HSETNX myhash field1 "bar"
(integer) -- 已存在的字段操作无效 -- Hvals 命令返回哈希表所有字段的值。
127.0.0.1:> hvals myhash
) "foo"

redis 系列12 哈希对象的更多相关文章

  1. Python操作redis系列以 哈希(Hash)命令详解(四)

    # -*- coding: utf-8 -*- import redis #这个redis不能用,请根据自己的需要修改 r =redis.Redis(host=") 1. Hset 命令用于 ...

  2. redis 系列14 有序集合对象

    一. 有序集合概述 Redis 有序集合对象和集合对象一样也是string类型元素的集合,且不允许重复的成员.不同的是每个元素都会关联一个double类型的分数.redis正是通过分数来为集合中的成员 ...

  3. 【目录】redis 系列篇

    随笔分类 - redis 系列篇 redis 系列27 Cluster高可用 (2) 摘要: 一. ASK错误 集群上篇最后讲到,对于重新分片由redis-trib负责执行,关于该工具以后再介绍.在进 ...

  4. Python操作redis系列之 列表(list) (四)

    # -*- coding: utf- -*- import redis r =redis.Redis(host=,password="ZBHRwlb1608") 1. Lpush ...

  5. Python操作redis系列之 列表(list) (五)(转)

    # -*- coding: utf-8 -*- import redis r =redis.Redis(host=") 1. Lpush 命令将一个或多个值插入到列表头部. 如果 key 不 ...

  6. Python操作redis系列之 列表(list) (五)

    # -*- coding: utf- -*- import redis r =redis.Redis(host=,password=") 1. Lpush 命令将一个或多个值插入到列表头部. ...

  7. redis 系列9 对象类型(字符串,哈希,列表,集合,有序集合)与数据结构关系

    一.概述 在前面章节中,主要了解了 Redis用到的主要数据结构,包括:简单动态字符串.链表(双端链表).字典.跳跃表. 整数集合.压缩列表(后面再了解).Redis没有直接使用这些数据结构来实现键值 ...

  8. redis 系列15 数据对象的(类型检查,内存回收,对象共享)和数据库切换

    一.  概述 对于前面的五章中,已清楚了数据对象的类型以及命令实现,其实还有一种数据对象为HyperLogLog,以后需要用到再了解.下面再了解类型检查,内存回收,对象共享,对象的空转时长. 1.1 ...

  9. redis系列之------对象

    前言 Redis 并没有直接使用数据结构来实现键值对数据库, 而是基于这些数据结构创建了一个对象系统, 这个系统包含字符串对象.列表对象.哈希对象.集合对象和有序集合对象这五种类型的对象, 每种对象都 ...

随机推荐

  1. Paxos协议超级详细解释+简单实例

    转载自:  https://blog.csdn.net/cnh294141800/article/details/53768464 Paxos协议超级详细解释+简单实例   Basic-Paxos算法 ...

  2. 2019 蓝桥杯省赛 A 组模拟赛(一)-修建公路

    题目: 蒜头国有 nn 座城市,编号分别为 0,1,2,3,...,n-1.编号为 x 和 y 的两座城市之间如果要修高速公路,必须花费 x|y 个金币,其中|表示二进制按位或. 吝啬的国王想要花最少 ...

  3. 微服务框架——SpringCloud(三)

    1.Zuul服务网关 作用:路由转发和过滤,将请求转发到微服务或拦截请求.Zuul默认集成了负载均衡功能. 2.Zuul实现路由 a.新建springboot项目,依赖选择 Eureka Discov ...

  4. unity打包exe中的资源管理

    给美术和产品用unity做一些exe工具,会频频遇到导入导出资源的情况. 首先所有的文件应该放在StreamingAssets文件夹下, 如果需要动态替换贴图,这样美术只要替换default.png就 ...

  5. 京东B2B业务架构演变

    京东 B2B 业务的定位是让各类型的企业都可以在京东的 B 平台上进行采购.建立采购关系. 京东 B2B 的用户群体主要分为 2 类,一类是大 B 用户.另一类是小 B 用户.比如联通.移动公司跟京东 ...

  6. golang实现障碍、转弯最少的A*寻路

    目录 目标: 要点: 源码: 目标: 优先寻找无障碍的路径 目标不可达时,寻找障碍最少的路径 路径长度相等时,优先转弯最少的路径 多个目标点时,根据以上要求到达其中一个目标点即可 要点: 最优格子的选 ...

  7. 编译部署 Mysql 5.7

    1.环境准备 RHEL7.4(最小化安装)  64bit   2G 内存 (1G 内存编译将近一个小时) 磁盘空间 15G 以上. 配置为本地yum 源 从MySQL5.7版本开始,安装MySQL需要 ...

  8. MySQL5.6启用sha256_password插件

    一.背景: 使用MySQL5.6过程中,发现默认的加密插件为mysql_native_password.而sha256_password的安全程度要比mysql_native_password高,尝试 ...

  9. web移动端开发技巧

    一.meta的使用 1.<meta name="viewport" content="width=device-width,initial-scale=1.0, m ...

  10. sublime No packages available for installation

    package control user-setting 中添加: "channels": [ "C:\\channel_v3.json" ], channel ...