redis 学习(4)-- 哈希类型
redis 学习(4)-- 哈希类型
介绍
redis 中哈希键值结构:
可以看出:哈希键值包括 key,field,value 这三部分,即键,属性,值这三部分。可以这样来表示:
key, (field, value)
即将 key, (field, value) 看成一组键值对,将 field, value 看成另一组键值对。
其中:
field 不能相同,value 可以相同
哈希其实就是一个 small redis。
API 介绍
命令 | 含义 |
---|---|
hget key field | 获取存储在哈希表中指定field的值 |
hset key field value | 将哈希表中指定field的值设置为value |
hdel key field1 [field2...] | 删除哈希表中一个或多个field |
hexists key field | 判断哈希表中,指定field是否存在 |
hlen key | 获取哈希表中字段的数量 |
hmget key field1 [field2...] | 取哈希表中所有给定field的值 |
hmset key field1 value1 [field2 value2...] | 同时将一个或多个field-value对设置到哈希表中 |
hincrby key fiel increment | 为哈希表中指定field的值加上一个整型增量 |
hsetnx key field value | 只有当哈希表中field不存在时,才设置该field的值 |
hincrbyfloat key field increment | 为哈希表中指定field的值加上一个浮点数增量 |
不建议使用的 API
hgetall key
- 含义:获取哈希表中所有字段和值
- 时间复杂度为O(n),不建议使用
hkeys key
- 含义:获取哈希表中的所有字段
- 时间复杂度为O(n),不建议使用
hvals key
- 含义:获取哈希表中的所有值
- 时间复杂度为O(n),不建议使用
演示
hget、hset、hdel
hexists、hlen
hmget、hmset
实战
- 实现如下功能:记录网站每个用户个人主页的访问量
hincrby user:1:info pageview count
- 实现如下功能:缓存视频的基本信息(数据源在MYSQL中)伪代码
public VideoInfo get(long id) {
String redisKey = redisPrefix + id;
Map<String,String> hashMap = redis.hgetAll(redisKey);
VideoInfo videoInfo = transferMapToVideo(hashMap);
if (videoInfo == null) {
videoInfo = mysql.get(id);
if (videoInfo != null) {
redis.hmset(redisKey, transferVideoToMap(videoInfo));
}
}
return videoInfo;
}
将数据缓存在哈希表中,做序列化,然后取出来,做反序列化。
String 和 Hash 比较
相似的 API
String | Hash |
---|---|
get | hget |
set setnx | hset hsetnx |
del | hdel |
incr incrby decr decrby | hincrby |
mset | hmset |
mget | hmget |
用户信息的实现
1. String 实现
set user:1:serialize(userinfo)
将用户信息序列化为 json、xml、protobuf 等对象,需要的时候再取出来。
2. String 实现 (V2)
set user:1:age 41
set user:1:link tv.sohu.com
将用户的每项信息依次设置 key 和 value。
3. Hash 实现
hset user:1:info: age 41
hset user:1:info link tv.sohu.com
将用户信息存到 哈希表中。
三种方案比较
命令 | 优点 | 缺点 |
---|---|---|
string v1 | 编程简单;可以节省内存 | 序列化开销;设置属性要操作整个数据 |
string v2 | 直观;可以部分更新 | 内存占用较大;key较为分散 |
hash | 直观;节省空间;可以部分更新 | 编程稍微复杂;ttl不好控制 |
redis 学习(4)-- 哈希类型的更多相关文章
- 第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型
第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型 Hash操作,redis中Hash在内存中的存储格式如下图: hset(name, key, value)name ...
- redis学习笔记-01 string类型命令
一.set key value set joker 123456 #设定key为joker,value为123456的数据 二.keys * keys * #用于查看该数据库中所有的key值 三.se ...
- 峰Redis学习(3)Redis 数据结构(字符串、哈希)
第一节:Redis 数据类型介绍 五种数据类型: 字符串(String) 字符串列表(list) 有序字符串集合(sorted set) 哈希(hash) 字符串集合(set) 第二节:Redis ...
- 【redis 学习系列】API的理解与使用(二)
3.哈希 几乎所有的语言都支持了哈希(hash)类型.在Redis中,哈希类型是指键值本身又是一个键值对结构,形如:value = {{field, value} ... {field, value} ...
- API的理解和使用——哈希类型的命令
哈希常用的命令复习 命令 功能 hset key field value 设置哈希值 hsetnx 设置哈希值,field或键必须不存在 hget 获取某个file对应的值 hdel 删除一个或多个f ...
- Redis学习——数据结构上
一.常用的全局命令 1.查看所有的键: KEYS * KEYS pattern:查找所有符合给定模式 pattern 的 key . KEYS 的速度非常快,但在一个大的数据库中使用它仍然可能造成性能 ...
- 尚硅谷redis学习4-数据类型
redis的数据类型包括String,Hash(类似于JAVA里的map),List,Set,Zset(sorted Set) String(字符串) string是redis最基本的类型,你可以理解 ...
- 【转】Redis学习---哈希结构内存模型剖析
[原文]https://www.toutiao.com/i6594624365906625032/ 概述 在前文<Redis字符串类型内部编码剖析>之中已经剖析过 Redis最基本的 St ...
- Redis之哈希类型命令
Hash(哈希) Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象. Redis 中每个 hash 可以存储 232 - 1 键值对(40多亿 ...
随机推荐
- 使用Telnet访问端口发送数据
什么是Telnet? 对于Telnet的认识,不同的人持有不同的观点,可以把Telnet当成一种通信协议,但是对于入侵者而言,Telnet只是一种远程登录的工具.一旦入侵者与远程主机建立了Telnet ...
- Java 实现 2的次幂表示
问题描述 任何一个正整数都可以用2进制表示,例如:137的2进制表示为10001001. 将这种2进制表示写成2的次幂的和的形式,令次幂高的排在前面,可得到如下表达式:137=2^7+2^3+2^0 ...
- docker Swarm mode集群
基本概念 Swarm 是使用 SwarmKit 构建的 Docker 引擎内置(原生)的集群管理和编排工具. 使用 Swarm 集群之前需要了解以下几个概念. 节点 运行 Docker 的主机可以主动 ...
- shiro环境搭建及基本操作
一.pom.xml <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www ...
- 微信小程序开发工具下载以及安装教程
微信公众平台上登录你的微信小程序账号 登录进入小程序开发-工具-下载,再根据你的系统选择相对应的版本地址进行下载. 以管理员身份运行下载,点击下一步,如图所示: 下一步,就会出现许可证协议 ...
- 小D课堂 - 新版本微服务springcloud+Docker教程_3-01 什么是微服务的注册中心
笔记 第三章 SpringCloud核心组件注册中心 1.什么是微服务的注册中心 简介:讲解什么是注册中心,常用的注册中心有哪些 (画图) 理解注册中心:服务 ...
- 八十三:redis之redis的使用场景和安装
使用场景1.登录会话存储,存储在redis中,与mamcached相比,数据不会丢失2.排行榜.计数器:比如一些秀场类的项目,经常会有一些前多少名的主播排行榜,还有一些文章阅读量.或者点赞数等3.作为 ...
- AIxoder插件安装及使用
参考:https://www.aixcoder.com/#/Download 右边有快捷导航,查看对应需要的问题 1.下载AIxcoder 2.安装并注册打开 3.给IDE安装 4.验证是否安装成 ...
- datatable 用法
DataTable datainsert = dt.GetChanges(DataRowState.Added); DataTable datadelete = dt.GetChanges(DataR ...
- Python3命名规范
1.模块 模块尽量使用小写命名,首字母保持小写,尽量不要用下划线(除非多个单词,且数量不多的情况) # 正确的模块名 import decoder import html_parser # 不推荐的模 ...