Redis--hash类型

本文涉及的产品
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 Tair(兼容Redis),内存型 2GB
简介: Redis--hash类型

Redis–hash类型

最重要的数据结构,没有之一!!


基本命令

1. hset && hget

# field 对应的value只能是string类型
hset key field value [field value ...]
hget key field


2. hexists

判断key里的field是否存在。

hexists key field


3. hdel

删除key里的field。(del 是直接删除key)

hdel key field [field ...]


4. hkeys && hvals && hgetall

hkeys获取key中的所有field。


hvals获取key中的所有value。


hgetall获取key中的所有field和value。


(有风险,若key中有大量的field,会导致Redis服务器被阻塞!! keys *命令也是一样的。)


可以使用hscan命令获取所有的field,他采用渐进式遍历,就是一次遍历一部分,在执行一次遍历下一部分(化整为零)…可以防止Redis服务器被阻塞。

hkeys key
hvals key
hgetall key


5. hmget

一次查询一个key里的多个field。(hset可以一次设置多个field,但是hget只能获取一个field)

hmget key field1 [field2 ...]


6. hlen

获取key中field的个数。

hlen key


7. hsetnx

在field不存在时设置其field--value,key 中存在相应的field时设置失败。

hsetnx key field value


8. hincrby && hincrbyfloat

将field对应的value加减整数/小数。

hincrby key field 10
hincrby key field -10
hincrbyfloat key field 0.2
hincrbyfloat key field -0.2


9. hstrlen

获取value字符串的长度,单位:字节。

hstrlen key field


hash类型内部编码

1. ziplist

在field个数较少 并且每个value不长时使用,节省内存。


2. hashtable

标准的哈希表。


查看内部编码:

object encoding key


hash类型的应用场景

1. 用作缓存

哈希类型存储会更直观,在更新操作时也会更灵活。但是内存使用量会更大。


如果用string类型存储相应的数据就要用到json串,修改很麻烦,要转换成哈希类型修改,然后再写成json串(但是json方式更节省空间)!!而直接使用哈希类型就很灵活。


相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
4月前
|
负载均衡 NoSQL 算法
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
这篇文章是关于Java面试中Redis相关问题的笔记,包括Redis事务实现、集群方案、主从复制原理、CAP和BASE理论以及负载均衡算法和类型。
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
|
1月前
|
存储 消息中间件 NoSQL
Redis数据结构:List类型全面解析
Redis数据结构——List类型全面解析:存储多个有序的字符串,列表中每个字符串成为元素 Eelement,最多可以存储 2^32-1 个元素。可对列表两端插入(push)和弹出(pop)、获取指定范围的元素列表等,常见命令。 底层数据结构:3.2版本之前,底层采用**压缩链表ZipList**和**双向链表LinkedList**;3.2版本之后,底层数据结构为**快速链表QuickList** 列表是一种比较灵活的数据结构,可以充当栈、队列、阻塞队列,在实际开发中有很多应用场景。
|
2月前
|
消息中间件 存储 监控
redis 的List类型 实现 排行榜
【10月更文挑战第8天】
42 2
|
2月前
|
存储 NoSQL Redis
redis-set类型
【10月更文挑战第6天】
46 1
|
2月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
28 3
|
2月前
|
消息中间件 分布式计算 NoSQL
大数据-41 Redis 类型集合(2) bitmap位操作 geohash空间计算 stream持久化消息队列 Z阶曲线 Base32编码
大数据-41 Redis 类型集合(2) bitmap位操作 geohash空间计算 stream持久化消息队列 Z阶曲线 Base32编码
28 2
|
1月前
|
存储 NoSQL 关系型数据库
Redis的ZSet底层数据结构,ZSet类型全面解析
Redis的ZSet底层数据结构,ZSet类型全面解析;应用场景、底层结构、常用命令;压缩列表ZipList、跳表SkipList;B+树与跳表对比,MySQL为什么使用B+树;ZSet为什么用跳表,而不是B+树、红黑树、二叉树
|
3月前
|
JSON 缓存 NoSQL
redis序列化数据时,如何包含clsss类型信息?
通过配置 `com.fasterxml.jackson.databind.ObjectMapper` 的 `enableDefaultTyping` 方法,可以使序列化后的 JSON 包含类信息。
55 2
|
2月前
|
消息中间件 NoSQL Kafka
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
184 0
|
6月前
|
NoSQL Redis C语言
[hiredis 的Redis执行语句返回结果类型全说明
[hiredis 的Redis执行语句返回结果类型全说明
57 1