redis 系列12 哈希对象
一. 哈希对象概述
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 哈希对象的更多相关文章
- Python操作redis系列以 哈希(Hash)命令详解(四)
# -*- coding: utf-8 -*- import redis #这个redis不能用,请根据自己的需要修改 r =redis.Redis(host=") 1. Hset 命令用于 ...
- redis 系列14 有序集合对象
一. 有序集合概述 Redis 有序集合对象和集合对象一样也是string类型元素的集合,且不允许重复的成员.不同的是每个元素都会关联一个double类型的分数.redis正是通过分数来为集合中的成员 ...
- 【目录】redis 系列篇
随笔分类 - redis 系列篇 redis 系列27 Cluster高可用 (2) 摘要: 一. ASK错误 集群上篇最后讲到,对于重新分片由redis-trib负责执行,关于该工具以后再介绍.在进 ...
- Python操作redis系列之 列表(list) (四)
# -*- coding: utf- -*- import redis r =redis.Redis(host=,password="ZBHRwlb1608") 1. Lpush ...
- Python操作redis系列之 列表(list) (五)(转)
# -*- coding: utf-8 -*- import redis r =redis.Redis(host=") 1. Lpush 命令将一个或多个值插入到列表头部. 如果 key 不 ...
- Python操作redis系列之 列表(list) (五)
# -*- coding: utf- -*- import redis r =redis.Redis(host=,password=") 1. Lpush 命令将一个或多个值插入到列表头部. ...
- redis 系列9 对象类型(字符串,哈希,列表,集合,有序集合)与数据结构关系
一.概述 在前面章节中,主要了解了 Redis用到的主要数据结构,包括:简单动态字符串.链表(双端链表).字典.跳跃表. 整数集合.压缩列表(后面再了解).Redis没有直接使用这些数据结构来实现键值 ...
- redis 系列15 数据对象的(类型检查,内存回收,对象共享)和数据库切换
一. 概述 对于前面的五章中,已清楚了数据对象的类型以及命令实现,其实还有一种数据对象为HyperLogLog,以后需要用到再了解.下面再了解类型检查,内存回收,对象共享,对象的空转时长. 1.1 ...
- redis系列之------对象
前言 Redis 并没有直接使用数据结构来实现键值对数据库, 而是基于这些数据结构创建了一个对象系统, 这个系统包含字符串对象.列表对象.哈希对象.集合对象和有序集合对象这五种类型的对象, 每种对象都 ...
随机推荐
- linux 访问到对应的接口
8080端口已经打开. 8080端口已被监听 telnet 192.168.163.128 8080 成功 也可以将防火墙关闭,这样所有的接口已经开放,不会再被拦截.这种情况下只要8080端口被某 ...
- Game 23
Polycarp plays "Game 23". Initially he has a number nn and his goal is to transform it to ...
- 更新mysql驱动5.1-47 Generated keys not requested. You need to specify Statement.RETURN_GENERATED_KEY
今天在更新mysql驱动后运行程序突然报如下错误: java.sql.SQLException: Generated keys not requested. You need to specify S ...
- C# 0xC0000005 捕获
[HandleProcessCorruptedStateExceptions]//捕获c++异常 [SecurityCritical]//捕获c++异常 public void xxx() { try ...
- js基础知识易错点(一)
最近替另一个项目招人,要求基础知识好,随便问了一些基础题,发现了一些易错的点,总结一下. 1.判断一个空数组 var arr = []; 1)JSON.stringify(arr) == " ...
- Android中的数据持久化机制
Android中几种最简单但是却最通用的数据持久化技术:SharedPreference.实例状态Bundle和本地文件. Android的非确定性Activity和应用程序生存期使在会话间保留UI状 ...
- Linux 下的两个特殊的文件 -- /dev/null 和 /dev/zero 简介及对比
1.概论 -- 来自维基的解释 /dev/null : 在类Unix系统中,/dev/null,或称空设备,是一个特殊的设备文件,它丢弃一切写入其中的数据(但报告写入操作成功),读取它则会立即得到一 ...
- 解决fastJson无序问题
对外提供接口,第三方传过来的参数没问题.可是用fastJson 转换的出现 参数顺序不一致,导致 验签失败 解决fastJosn 转换无序问题 https://github.com/alibaba/f ...
- java爬虫案例学习
最近几天很无聊,学习了一下java的爬虫,写一些自己在做这个案例的过程中遇到的问题和一些体会1.学习目标 练习爬取京东的数据,图片+价格+标题等等 2.学习过程 1·开发工具 ...
- vi 配置
vim ~/.vimrc source ~/.vimrc 添加相关配置 一直生效 0 行首 $ 行尾 spacebar 空格键: 合并多行 spaceba ...