Redis:关于 redisTemplate.opsForSet().members(key)获取不了全部数据问题

本文主要是介绍Redis:关于 redisTemplate.opsForSet().members(key)获取不了全部数据问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题描述

今天遇到一个很神奇的问题,我使用redisTemplate.opsForSet().members(key)获取得到的结果,居然只有仅仅的一个。然而,我使用redisTemplate.opsForSet().size(key)得到的结果却比1要大,如我这里的是16.

问题分析

出于好奇,于是我就直接使用 redisTemplate.opsForSet().add(key2, values);来添加一系列的数据,如

 		for (int i = 10; i < 20; i++) {redisService.sAdd(String.class, "a", i + "");}List<String> set = redisService.smembers(String.class, "a");System.out.println(JSONUtil.toJsonStr(set));

然鹅,这里居然得到一个正确的答案!!确实是全部数据都找出来了!!所以可以确定,这个API肯定是没有问题的!!
于是,我决定慢慢的debug进去,这里肯定有我自己所忽略掉的东西!

接着,我在这方法里面,发现的神奇的东西
在这里插入图片描述
就是我得到的rawValues长度明明不是1(而是16),但是结果只有1个。
那么,问题就产生在 Set deserializeValues(Set<byte[]> rawValues)了

问题发现

在这里插入图片描述
所以,现在问题就明朗了,是这里的set把我们的结果给过滤掉了~简单点来说就是,我们的所有object返回的equals结果都是一致的 所以才导致set“帮”我们把结果都过滤掉了。

解决方案

那么 这就简单了,因为我们调用的时候,add进去的是一个object,而我们的object没有重写equals方法,那么我们就重写一下就好了。
例如我的是用id判断是否同一个obj,代码如下

    public boolean equals(Object e) {if (!(e instanceof MyData)) {return false;}return ((MyData) e).getId() == getId();}

运行验证

修改后,重新跑一遍~ 完美,就是这个原因(小松一口气,还以为我写的框架有问题呢~)

这篇关于Redis:关于 redisTemplate.opsForSet().members(key)获取不了全部数据问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/283218

相关文章

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

python实现对数据公钥加密与私钥解密

《python实现对数据公钥加密与私钥解密》这篇文章主要为大家详细介绍了如何使用python实现对数据公钥加密与私钥解密,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录公钥私钥的生成使用公钥加密使用私钥解密公钥私钥的生成这一部分,使用python生成公钥与私钥,然后保存在两个文

mysql中的数据目录用法及说明

《mysql中的数据目录用法及说明》:本文主要介绍mysql中的数据目录用法及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、版本3、数据目录4、总结1、背景安装mysql之后,在安装目录下会有一个data目录,我们创建的数据库、创建的表、插入的

MySQL 获取字符串长度及注意事项

《MySQL获取字符串长度及注意事项》本文通过实例代码给大家介绍MySQL获取字符串长度及注意事项,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 获取字符串长度详解 核心长度函数对比⚠️ 六大关键注意事项1. 字符编码决定字节长度2

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

Navicat数据表的数据添加,删除及使用sql完成数据的添加过程

《Navicat数据表的数据添加,删除及使用sql完成数据的添加过程》:本文主要介绍Navicat数据表的数据添加,删除及使用sql完成数据的添加过程,具有很好的参考价值,希望对大家有所帮助,如有... 目录Navicat数据表数据添加,删除及使用sql完成数据添加选中操作的表则出现如下界面,查看左下角从左

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM