RedisTemplate操作哈希数据

RedisTemplate操作哈希数据

  • 概述
  • 常用方法
    • 添加哈希数据
      • 添加hashMap值
      • 判断hashkey
    • 获取哈希数据
      • 获取属性值
      • 获取hashMap值。
      • 获取键值对。
      • 获取map键是否有值
      • 判断是否有map键。
      • 获取键。
      • 获取长度。
      • 集合方式获取值。
      • 匹配获取键值对
    • 自增
      • 以double值大小自增。
      • 以long值大小自增。
    • 修改删除
      • 修改哈希数据中的某个属性值
      • 删除哈希数据中的某个属性值
      • 删除哈希表

在这里插入图片描述

主页传送门:📀 传送

概述


  Redis是一个开源的内存数据结构存储系统,它可以用作数据库、缓存和消息代理。Redis 的核心是提供数据类型的集合,在Redis中,有多种数据结构,如字符串、列表、集合、有序集合和哈希表,它可以帮助解决从缓存到队列再到事件处理的各种问题。

  RedisTemplate是Spring Data Redis提供的一个用于操作Redis的模板类,它提供了丰富的方法来操作Redis中的哈希数据。

常用方法


  本文来介绍下一些常用的使用RedisTemplate操作哈希数据的方法及简单示例。

添加哈希数据


  向Redis中的哈希表中添加数据,可以使用opsForHash()方法获取哈希操作对象,然后调用putAll()方法。

示例:

@Resource
private RedisTemplate<String, Object> redisTemplate;

public void addHashData(String key, Map<String, Object> hashData) {
    redisTemplate.opsForHash().putAll(key, hashData);
    Map newMap = new HashMap();  
    newMap.put("map3","map3-3");  
    newMap.put("map5","map5-5");  
    redisTemplate.opsForHash().putAll("hashValue",newMap);  
    map = redisTemplate.opsForHash().entries("hashValue");  
    System.out.println("通过putAll(H key, Map<? extends HK,? extends HV> m)方法以map集合的形式添加键值对:" + map); 
}

添加hashMap值


  向Redis中的哈希表中添加hashMap值,可以使用opsForHash()方法获取哈希操作对象,然后调用put(H key, HK hashKey, HV value)方法。

示例:

@Resource
private RedisTemplate<String, Object> redisTemplate;

public void addHashMapValue(String key, String hashKey, String value) {
    redisTemplate.opsForHash().put("hashValue","map1","map1-1");  
    redisTemplate.opsForHash().put("hashValue","map2","map2-2"); 
    redisTemplate.opsForHash().put(key, hashKey, value); 
} 

判断hashkey


  Redis中的哈希表判断hashkey是否存在,可以使用putIfAbsent(H key, HK hashKey, HV value)方法判断hashkey是否存在,如果hashKey存在,啥也不操作,如果hashKey不存在,则新增。

示例:


    redisTemplate.opsForHash().putIfAbsent("hashValue","map6","map6-6");  
    map = redisTemplate.opsForHash().entries("hashValue");  
    System.out.println("通过putIfAbsent(H key, HK hashKey, HV value)方法添加不存在于变量中的键值对:" + map); 

获取哈希数据


  从Redis中的哈希表中获取数据,可以使用opsForHash()方法获取哈希操作对象,然后调用entries()方法。

示例:

public Map<Object, Object> getHashData(String key) {
    return redisTemplate.opsForHash().entries(key);
}

获取属性值


  从Redis中的哈希表中获取某个属性的值,可以使用opsForHash()方法获取哈希操作对象,然后调用get()方法:

示例:

public Object getHashDataValue(String key, String field) {
    return redisTemplate.opsForHash().get(key, field);
}

获取hashMap值。


   获取指定变量中的hashMap值,通过values(H key)方法获取变量中的hashMap值

示例:

values(H key)
List<Object> hashList = redisTemplate.opsForHash().values("hashValue");  
System.out.println("通过values(H key)方法获取变量中的hashMap值:" + hashList); 

获取键值对。


   通过entries(H key)方法获取变量中的键值对

示例:

entries(H key)
Map<Object,Object> map = redisTemplate.opsForHash().entries("hashValue");  
System.out.println("通过entries(H key)方法获取变量中的键值对:" + map);

获取map键是否有值


  获取变量中的指定map键是否有值,如果存在该map键则获取值,没有则返回null。

示例:

   get(H key, Object hashKey)
    Object mapValue = redisTemplate.opsForHash().get("hashValue","map1");  
    System.out.println("通过get(H key, Object hashKey)方法获取map键的值:" + mapValue); 

判断是否有map键。


   通过hasKey(H key, Object hashKey)方法判断变量中是否存在map键

示例:

    hasKey(H key, Object hashKey)
    
    boolean hashKeyBoolean = redisTemplate.opsForHash().hasKey("hashValue","map3");  
    System.out.println("通过hasKey(H key, Object hashKey)方法判断变量中是否存在map键:" + hashKeyBoolean);   

获取键。


   通过keys(H key)方法获取变量中的键

示例:

    
    keys(H key)
    
    Set<Object> keySet = redisTemplate.opsForHash().keys("hashValue");  
    System.out.println("通过keys(H key)方法获取变量中的键:" + keySet);  

获取长度。


   通过size(H key)方法获取变量的长度

示例:

    size(H key)
    
    long hashLength = redisTemplate.opsForHash().size("hashValue");  
    System.out.println("通过size(H key)方法获取变量的长度:" + hashLength); 

集合方式获取值。


   通过multiGet(H key, Collection hashKeys)方法以集合的方式获取变量中的值

示例:

    multiGet(H key, Collection<HK> hashKeys)
    
    List<Object> list = new ArrayList<Object>();  
    list.add("map1");  
    list.add("map2");  
    List mapValueList = redisTemplate.opsForHash().multiGet("hashValue",list);  
    System.out.println("通过multiGet(H key, Collection<HK> hashKeys)方法以集合的方式获取变量中的值:"+mapValueList); 

匹配获取键值对


   匹配获取键值对,通过scan(H key, ScanOptions options)方法获取匹配键值对,ScanOptions.NONE为获取全部键对,ScanOptions.scanOptions().match(“map1”).build() 匹配获取键位map1的键值对,不能模糊匹配。

示例:

    scan(H key, ScanOptions options)
   
    Cursor<Map.Entry<Object,Object>> cursor = redisTemplate.opsForHash().scan("hashValue",ScanOptions.scanOptions().match("map1").build());  
    //Cursor<Map.Entry<Object,Object>> cursor = redisTemplate.opsForHash().scan("hashValue",ScanOptions.NONE);  
    while (cursor.hasNext()){  
        Map.Entry<Object,Object> entry = cursor.next();  
        System.out.println("通过scan(H key, ScanOptions options)方法获取匹配键值对:" + entry.getKey() + "---->" + entry.getValue());  
    }  

自增


以double值大小自增。


   通过increment(H key, HK hashKey, double delta)方法使变量中的键以值的大小进行自增长

示例:

increment(H key, HK hashKey, double delta) 

double hashIncDouble = redisTemplate.opsForHash().increment("hashInc","map1",3);  
System.out.println("通过increment(H key, HK hashKey, double delta)方法使变量中的键以值的大小进行自增长:" + hashIncDouble);  

以long值大小自增。


   通过increment(H key, HK hashKey, long delta)方法使变量中的键以值的大小进行自增长

示例:

increment(H key, HK hashKey, long delta)

long hashIncLong = redisTemplate.opsForHash().increment("hashInc","map2",6);  
System.out.println("通过increment(H key, HK hashKey, long delta)方法使变量中的键以值的大小进行自增长:" + hashIncLong);  

修改删除


修改哈希数据中的某个属性值


   修改Redis中的哈希表中某个属性的值,可以使用opsForHash()方法获取哈希操作对象,然后调用put()方法。

示例:

public void updateHashDataValue(String key, String field, Object newValue) {
    redisTemplate.opsForHash().put(key, field, newValue);
}

删除哈希数据中的某个属性值


   从Redis中的哈希表中删除某个属性的值,可以使用opsForHash()方法获取哈希操作对象,然后调用delete()方法。

示例:

public void deleteHashDataValue(String key, String field) {
    redisTemplate.opsForHash().delete(key, field);
}

删除哈希表


   要删除Redis中的整个哈希表,可以使用delete()方法。示例:

public void deleteHashTable(String key) {
    redisTemplate.delete(key);
    delete(H key, Object... hashKeys)
    删除变量中的键值对,可以传入多个参数,删除多个键值对。
    redisTemplate.opsForHash().delete("hashValue","map1","map2");  
    map = redisTemplate.opsForHash().entries("hashValue");  
    System.out.println("通过delete(H key, Object... hashKeys)方法删除变量中的键值对后剩余的:" + map); 
}

在这里插入图片描述

  如果喜欢的话,欢迎 🤞关注 👍点赞 💬评论 🤝收藏  🙌一起讨论
  你的支持就是我✍️创作的动力!					  💞💞💞

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/230804.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

流程画布开发技术方案归档(G6)

&#x1f3a8; 在理想的最美好世界中&#xff0c;一切都是为最美好的目的而设。 —— 伏尔泰 如果可以实现记得点赞分享&#xff0c;谢谢老铁&#xff5e; 一、技术选型 •从可维护性和可拓展性出发 •基本满足 1&#xff1a;链接: https://github.com/hukaibaihu/vue-org…

伦茨科技宣布ST17H6x芯片已通过Apple Find My「查找」认证

深圳市伦茨科技有限公司&#xff08;以下简称“伦茨科技”&#xff09;发布ST17H6x Soc平台。成为继Nordic之后全球第二家取得Apple Find My「查找」认证的芯片厂家&#xff0c;该平台提供可通过Apple Find My认证的Apple查找&#xff08;Find My&#xff09;功能集成解决方案。…

MPEG4Extractor

1、readMetaData 必须要找到 Moov box&#xff0c;找到 Mdat box或者 Moof box&#xff0c;并且创建了 ItemTable 大端 box 分为 box header 和 box content&#xff1a; box header由8个字节组成&#xff0c;前面四个字节表示这个box 的大小&#xff08;包含这个头的8字节&a…

MySQL数据库,子查询

子查询指一个查询语句嵌套在另一个查询语句内部的查询。很多时候查询需要从结果集中获取数据&#xff0c;或者需要从同一个表中先计算得出一个数据结果&#xff0c;然后与这个数据结果&#xff08;可能是某个标量&#xff0c;也可能是某个集合&#xff09;进行比较。 例&#…

微信小程序适配方案:rpx(responsive pixel响应式像素单位)

小程序适配单位&#xff1a;rpx 规定任何屏幕下宽度为750rpx 小程序会根据屏幕的宽度自动计算rpx值的大小 Iphone6下&#xff1a;1rpx 1物理像素 0.5css 小程序编译后&#xff0c;rpx会做一次px换算&#xff0c;换算是以375个物理像素为基准&#xff0c;也就是在一个宽度…

通用基础模型+提示词是否能胜过微调模型?医学案例研究

论文链接在末尾 摘要 通用基础模型,如GPT-4,在各种领域和任务中展现出令人惊讶的能力。然而,普遍存在这样一种假设,即它们在没有专业知识深度训练的情况下无法达到专业能力。例如,迄今为止对医学竞赛基准的大多数探索都利用了领域特定的训练,正如在BioGPT和Med-PaLM等项…

基于Python+WaveNet+MFCC+Tensorflow智能方言分类—深度学习算法应用(含全部工程源码)(二)

目录 前言引言总体设计系统整体结构图系统流程图 运行环境模块实现1. 数据预处理1&#xff09;数据介绍2&#xff09;数据测试3&#xff09;数据处理 相关其它博客工程源代码下载其它资料下载 前言 博主前段时间发布了一篇有关方言识别和分类模型训练的博客&#xff0c;在读者…

ooTD I 这么精致优雅的套装也太好看了吧

精致到每一个细节的国风套装 领口袖口拼接环保毛条 精美的绣花增添浓重的高级感 外套90白鸭绒填充 敲暖和裙子的门襟处 也是做了定制盘扣&#xff0c;外套和裙子单独来穿也很精致

章鱼网络进展月报 | 2023.11.1-11.30

章鱼网络大事摘要 1、2023年12月&#xff0c;Octopus 2.0 将会正式启动。 2、隐私协议 Secret Network 宣布使用 Octopus Network 构建的 NEAR-IBC 连接 NEAR 生态。 3、Louis 受邀作为嘉宾&#xff0c;在 NEARCON2023 的多链网络主题沙龙中发言&#xff1a;我们依然处于区…

主存储器与CPU的连接

目录 一. 单块存储芯片与CPU的连接二. 多块存储芯片与CPU的连接2.1 位扩展2.2 字扩展2.3 字位扩展 三. 译码器知识点的补充 \quad 一. 单块存储芯片与CPU的连接 \quad \quad \quad 暴露出的引脚都是与CPU连接的 上面这个是88位的存储芯片 我们可以看到有8个字, 每个字的字长是8…

Git提交代码时出现: ‘LF will be replaced by CRLF the next time Git touches it‘

遇到的问题 windows平台进行 git add 时&#xff0c;控制台打印警告 问题分析 1. Dos/Windows平台默认换行符&#xff1a;回车&#xff08;CR&#xff09;换行&#xff08;LF&#xff09;&#xff0c;即’\r\n’ 2. Mac/Linux平台默认换行符&#xff1a;换行&#xff08;LF&…

imazing正在查找最新的apple mobile device组件

​ Apple Mobile Device是macOS的一个组件&#xff0c;它允许您在Mac上与iOS设备进行无缝连接和通信。因此&#xff0c;无法直接在苹果设备上下载和安装Apple Mobile Device&#xff0c;需要借助管理工具进行下载安装后启动。 如果您需要与iOS设备进行通信和同步&#xff0c;…

javascript实现Stack(栈)数据结构

上一篇文章我们理解了List这种数据结构&#xff0c;知道了它的特点和一些使用场景&#xff0c;这篇文章我们就来看一下栈这种数据结构&#xff0c;这里的栈可不是客栈哦&#xff0c;哈哈 栈其实和List非常像&#xff0c;使用javascript实现都是基于数组来实现 尝试理解Stack …

10 大 Android 手机系统修复软件深度评测

您的新 Android 手机可能因其令人兴奋的性能而印象深刻。然而&#xff0c;随着时间的推移&#xff0c;您可能会发现系统有些地方与以前不太一样。您可能会遇到屏幕无响应、 Android应用程序崩溃、连接问题、电池耗尽等现象。 10 大 Android 手机系统修复软件 好吧&#xff0c;…

【51单片机系列】74HC595实现对LED点阵的控制

本文是关于LED点阵的使用&#xff0c;使用74HC595模块实现对LED点阵的控制。 文章目录 一、8x8LED点阵的原理1.1 LED点阵显示原理1.2 LED点阵内部结构图1.3 开发板上的LED点阵原理图1.4 74HC595芯片 二、使用74HC595模块实现流水灯效果三、 使用74HC595模块控制LED点阵对角线亮…

【数据结构和算法】--- 栈

目录 栈的概念及结构栈的实现初始化栈入栈出栈其他一些栈函数 小结栈相关的题目 栈的概念及结构 栈是一种特殊的线性表。相比于链表和顺序表&#xff0c;栈只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶&#xff0c;另一端称为栈底。栈中的…

LeetCode力扣每日一题(Java):26、删除有序数组中的重复项

一、题目 二、解题思路 1、我的思路 我一开始的思路是创建一个ArrayList对象&#xff0c;然后将数组中的元素追加到ArrayList中&#xff0c;再通过ArrayList提供的API去解题&#xff0c;但是发现题目中提到了原地删除重复的元素&#xff0c;所以这种方法是行不通的 那就只能…

智能优化算法应用:基于袋獾算法无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用&#xff1a;基于袋獾算法无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用&#xff1a;基于袋獾算法无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.袋獾算法4.实验参数设定5.算法结果6.参考文献7.MATLAB…

使用LangSmith来快速学习LangChain

好风凭借力&#xff0c;送我上青云&#xff01; 什么是LangSmith LangSmith is a platform for building production-grade LLM applications. It lets you debug, test, evaluate, and monitor chains and intelligent agents built on any LLM framework and seamlessly int…

【数据结构】——队列实现二叉树的功能

前言&#xff1a;二叉树的实现方式多种多样&#xff0c;有数组实现满二叉树&#xff0c;有链表实现完全二叉树&#xff0c;今天我们就用队列来实现二叉树。 创建二叉树&#xff1a; typedef int BTDataType; typedef struct BinaryTreeNode {BTDataType data;struct BinaryTre…