RedisTemplate和StringRedisTemplate的区别、对比

学习

Jedis、RedisTemplate、StringRedisTemplate之间的比较

博客中提到:一. Jedis是Redis官方推荐的面向Java的操作Redis的客户端。

二. RedisTemplate,StringRedisTemplate是SpringDataRedis中对JedisApi的高度封装。SpringDataRedis相对于Jedis来说可以方便地更换Redis的Java客户端,比Jedis多了自动管理连接池的特性,方便与其他Spring框架进行搭配使用如:SpringCache。

三. StringRedisTemplate继承RedisTemplate,StringRedisTemplate只能管理StringRedisTemplate里面的数据,RedisTemplate只能管理RedisTemplate中的数据。

四. RedisTemplate使用的是JdkSerializationRedisSerializer 存入数据会将数据先序列化成字节数组然后在存入Redis数据库。StringRedisTemplate使用的是StringRedisSerializer序列化。

五.当你的redis数据库里面本来存的是字符串数据或者你要存取的数据就是字符串类型数据的时候,那么你就使用StringRedisTemplate即可。但是如果你的数据是复杂的对象类型,而取出的时候又不想做任何的数据转换,直接从Redis里面取出一个对象,那么使用RedisTemplate是更好的选择。


版权声明:以上为CSDN博主「wangdh258」的原创文章。

实验


StringredisTemplate--RedisDesktopManager

java 复制代码
stringRedisTemplate.opsForValue().setIfAbsent("encryptFlagTest", String.valueOf("1"));


RedisTemplate--RedisDesktopManager

java 复制代码
RedisTemplate.opsForValue().setIfAbsent("encryptFlag", String.valueOf("1"));

读取

java 复制代码
//stringRedisTemplate读取stringRedisTemplate存的数据
stringRedisTemplate.opsForValue().get("encryptFlagTest");
//输出
[==用StringredisTemplate读取StringredisTemplate:1]|
java 复制代码
//用redisTemplate读取redisTemplate
redisTemplate.opsForValue().get("encryptFlag");
//输出
|[==用redisTemplate读取redisTemplate:1]|
java 复制代码
//stringRedisTemplate读取RedisTemplate存的数据
stringRedisTemplate.opsForValue().get("encryptFlag");
//输出
|[==用stringRedisTemplate读取redisTemplate:�� t 1]|
java 复制代码
//用redisTemplate读取stringredisTemplate
redisTemplate.opsForValue().get("encryptFlagTest");
//输出
getBean|+|restExceptionCallbackSerivce not found|
|2023-08-21 10:44:59,367|+|,|+|CCIMP-SUBNOA-MS-carstage|+|ERROR|+|7588-httpWorkerThread-8084-2-30|+|c.e.r.p.e.PoinRestExceptionMapper:202|+|buildErrorMsg|+|系统处理异常!|
org.springframework.data.redis.serializer.SerializationException: Cannot deserialize; nested exception is org.springframework.core.serializer.support.SerializationFailedException: Failed to deserialize payload. Is the byte array a result of corresponding serialization for DefaultDeserializer?; nested exception is java.io.EOFException
at org.springframework.data.redis.serializer.JdkSerializationRedisSerializer.deserialize
相关推荐
雪的季节6 分钟前
qt信号槽跨线程使用时候的坑
java·开发语言·qt
chh56312 分钟前
C++--内存管理
java·c语言·c++·windows·学习·面试
白緢30 分钟前
嵌入式 Linux + 内核开发高频问题及排查
java·linux·运维
深蓝电商API35 分钟前
Redis在海淘场景下的缓存策略设计
数据库·redis·缓存·海淘
杰克尼36 分钟前
redis(day04-达人探店)
数据库·redis·缓存
juniperhan42 分钟前
Flink 系列第4篇:Flink 时间系统与 Timer 定时器实战精讲
java·大数据·数据仓库·flink
超级大只老咪44 分钟前
一维度前缀和解题通用模板(java)
java·开发语言·算法
历程里程碑1 小时前
1 . Git本地操作:版本控制 跨平台协作 仓库核心
java·开发语言·数据结构·c++·git·gitee·github
hekung1 小时前
maven的lifecycle与idea的run
java·maven
阿维的博客日记1 小时前
为什么 ConcurrentHashMap 采用 synchronized 加锁而不采用ReentrantLock
java·juc