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 并没有直接使用数据结构来实现键值对数据库, 而是基于这些数据结构创建了一个对象系统, 这个系统包含字符串对象.列表对象.哈希对象.集合对象和有序集合对象这五种类型的对象, 每种对象都 ...
随机推荐
- centos7基于samba服务配置实例
需求: 账号建立:产研部门所有人员,产品.开发.测试.运维: 目录建立:各二级部门分别建立以部门名称为文件夹的目录: 初步权限管理:各部门成员对本部门目录有读写权限,对其他部门目录有读权限: 建立共享 ...
- [CF1093E]Intersection of Permutations
[CF1093E]Intersection of Permutations 题目大意: 给定两个长度为\(n(n\le2\times10^5)\)的排列\(A,B\).\(m(m\le2\times1 ...
- vs2015配置OpenCV遇到的问题
OpenCV的配置过程可以参考博文:https://www.cnblogs.com/linshuhe/p/5764394.html 简要记载配置过程: 1.官网下载OpenCV安装包,并解压到目录,例 ...
- json格式的数据及遍历:
代码: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8 ...
- 网页加水印 svg 方式
/** *网页加水印 svg 方式 * * @export * @param {*} [{ * container = document.body, * content = '请勿外传', * wid ...
- prometheus — nginx-vts-exporter
参考文档: https://blog.51cto.com/xujpxm/2080146 注: 本文留用自己参考,建议看以上参考文档,更为细致 prometheus 监控 nginx 使用 nginx- ...
- [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 ...
- Flutter 读写本地文件
文档 注意 安装 path_provider 插件后重启f5, 而不是等待热更新 demo import 'dart:io'; import 'dart:async'; import 'package ...
- 用递归方法求n的阶乘
代码: #include<iostream> using namespace std; int fact(int n); int main() { int n; loop: cin > ...
- 接口自动化集成到jenkins(Java+testng+maven+git)
一jenkins启动命令:jenkins 查看端口号: 1.lsof -i:端口号 2.netstat -tunlp|grep 端口号 二: 登录:http://localhost:8080 输入:u ...