一. 哈希对象概述

  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. centos7基于samba服务配置实例

    需求: 账号建立:产研部门所有人员,产品.开发.测试.运维: 目录建立:各二级部门分别建立以部门名称为文件夹的目录: 初步权限管理:各部门成员对本部门目录有读写权限,对其他部门目录有读权限: 建立共享 ...

  2. [CF1093E]Intersection of Permutations

    [CF1093E]Intersection of Permutations 题目大意: 给定两个长度为\(n(n\le2\times10^5)\)的排列\(A,B\).\(m(m\le2\times1 ...

  3. vs2015配置OpenCV遇到的问题

    OpenCV的配置过程可以参考博文:https://www.cnblogs.com/linshuhe/p/5764394.html 简要记载配置过程: 1.官网下载OpenCV安装包,并解压到目录,例 ...

  4. json格式的数据及遍历:

    代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8 ...

  5. 网页加水印 svg 方式

    /** *网页加水印 svg 方式 * * @export * @param {*} [{ * container = document.body, * content = '请勿外传', * wid ...

  6. prometheus — nginx-vts-exporter

    参考文档: https://blog.51cto.com/xujpxm/2080146 注: 本文留用自己参考,建议看以上参考文档,更为细致 prometheus 监控 nginx 使用 nginx- ...

  7. [LeetCode] Score After Flipping Matrix 翻转矩阵后的分数

    We have a two dimensional matrix A where each value is 0 or 1. A move consists of choosing any row o ...

  8. Flutter 读写本地文件

    文档 注意 安装 path_provider 插件后重启f5, 而不是等待热更新 demo import 'dart:io'; import 'dart:async'; import 'package ...

  9. 用递归方法求n的阶乘

    代码: #include<iostream> using namespace std; int fact(int n); int main() { int n; loop: cin > ...

  10. 接口自动化集成到jenkins(Java+testng+maven+git)

    一jenkins启动命令:jenkins 查看端口号: 1.lsof -i:端口号 2.netstat -tunlp|grep 端口号 二: 登录:http://localhost:8080 输入:u ...