当前位置: 首页 > news >正文

Redis类型之Hash

1.hash常用操作 

      这里还是要强调,redis的类型指的是value的类型。故而这里的hash是把key这一层组织完成以后,到了value这一层,value的其中一种类型还可以是hash。

1.1 HSET 和 HGET

        HSET:设置hash类型的key

HSET key field value [field value ...]

        返回值是设置成功的键值对(field-value)的个数

        HGET:获取对应key中对应field的值

HGET key field

        返回值为查询key中对应的field对应的value,如果不存在则返回nil

1.2 HDEL

        HDEL:删除hash中指定的字段

        注意:del删除的key而hdel删除的field

HDEL key field [field ...]

        返回值为本次操作删除的字段个数

1.3 HKEYS

        HKEYS:这个操作,先根据key找到对应的value(hash),然后再遍历value

HKEYS key

        返回值就是这个key中所有的field        

        我上面这个操作存在一定的风险,就类似于之前的keys * ,如果key中的hash存在大量的field就有可能让我们的redis阻塞住。

1.4 HVALS

        HVALS:和hkeys相对能够获取到hash中的所有value

HVALS key

        返回值就是对应key中的所有field对应的值

1.5 HGETALL 

        HGETALL:查询value中的所有数据

HGETALL key

        返回值就是value中的所有数据包括field和value

        

        其实上面这样的操作风险还是有亿点大的,多数情况下,不需要查询所有的field,可能只需要查其中的几个field

1.6 HLEN

        HLEN:获取hash的元素个数,不需要遍历

HLEN key

        返回值就是hash的长度

1.7 HSETNX

        HSETNX:类似于setnx。不存在的时候,才能设置成功,如果存在则失败。

HSETNX key field value

        

1.8 常用操作小结

命令执行效果时间复杂度
hset key field value设置值O(1)
hget key field获取值O(1)
hdel key field [field ...]删除fieldO(k)
hlen key计算field个数O(1)
hgetall key获取所有的field-valueO(k)
hmget field [field ...]批量获取field-valueO(k)
hmset field value [field value ...]批量设置field-valueO(k)
hexists key field判断field是否存在O(1)
hkeys key获取所有的fieldO(k)
hvals key获取所有的valueO(k)
hsetnx key field value设置值,但必须再field不存在时才能设置成功O(1)
hincrbykey field n对应field-value + nO(1)
hincrbyfloat key field n对应field-value + nO(1)
hstrlen key field计算value的字符串长度O(1)

2.redis中的hash的内部编码

        rar、zip、gzip、7z...这些是具体的压缩算法

        压缩的本质是针对数据进行重新编码。不同的数据,有不同的特点,结合这些特点,进行精妙的设计,重新编码之后,就能缩小体积。类似的例子如下

2.2 ziplist

        ziplist存在的目的就是节省空间,ziplist内部的数据结构是精心设计的

        使用hash来表示一个普通的hash表,可能会浪费一定的空间(hash首先是一个数组,数组上有些位置有元素,有些没有)

        

3.redis中的hash的应用

http://www.dtcms.com/a/326308.html

相关文章:

  • 重学前端009 --- 响应式网页设计 CSS 伪选择器
  • 订单簿价格冲击模型与机器学习在大单策略中的融合
  • 元数据管理与数据治理平台:Apache Atlas 基本搜索 Basic Search
  • Apache Ignite分片线程池:高并发保序新方案
  • MCU 软件断点注意事项!!!
  • 【数据结构入门】树
  • 基于Go-Zero框架实现的小demo
  • 爬虫和数据分析相结合案例
  • 软件开发:一场精密的生命构建
  • 疯狂星期四文案网第36天运营日记
  • jsdiff + diff2html【jQuery】实现文件对比功能
  • Linux DNS服务解析原理与搭建
  • ResponseBodyAdvice是什么?
  • 基于动态顺序表实现【通讯录系统】:有文件操作部分哦!
  • Oracle主从incarnation不一致问题解决
  • ComfyUI安装
  • 【96页PPT】华为IPD流程管理详细版(附下载方式)
  • 强化学习常用数据集
  • HBase BlockCache:LRU Cache
  • Qt界面优化
  • TD-IDF的一些应用
  • 降压型DCDC电源芯片推荐-芯伯乐XBL4001 40V/5A
  • Python3.10 + Firecrawl 下载 Markdown 文档:构建高效通用文章爬虫
  • 深度学习 --- 迁移学习以及onnx推理
  • 自建Web应用防火墙(WAF)
  • 前端面试:promise...then与asnyc ...await
  • 华为Atlas 200 DK 板卡使用技巧记录(一)修改板卡IP
  • Pytest项目_day12(yield、fixture的优先顺序)
  • CobaltStrike钓鱼鱼饵制作的方式(chm、doc、execl、exe、powshell 上线cs)
  • [特殊字符] OpenCV图像预处理与ResNet-50深度学习分类实战