Java操控Redis (面经之 使用Redis)

操控Redis的工具 ReactiveRedisTemplate 和 RedisTemplate :

  • RedisTemplate

    • 它是一个通用的模板类,可以使用任何序列化策略来序列化和反序列化键和值。
    • 默认情况下,它使用 JdkSerializationRedisSerializer 序列化值,并使用 StringSerializer 序列化键。
    • 你可以通过设置不同的序列化器来改变序列化行为。
    • 这是一个阻塞的模板,适合于传统的同步编程模型。
  • ReactiveRedisTemplate

    • 这是一个反应式的模板类,它也是通用的,支持自定义序列化策略。
    • 它实现了 ReactiveRedisOperations 接口,提供了非阻塞的方法调用。
    • 适用于需要异步处理和高并发的场景。

opsforValue, opsforSet, opsforList 等等 对应 Java的数据结构 , 和 MySQL中的字段类型:

OpsForValue, OpsForSet, OpsForList, OpsForHash, OpsForZSet 等等都是 ReactiveRedisTemplateRedisTemplate 对象中的方法,它们分别用于操作 Redis 中不同数据类型的键值对。

以下是一些常见的 Java 数据结构以及 MySQL 数据类型与 Redis 数据类型的对应关系:

  • Value(字符串)

    • Java 数据结构:String
    • MySQL 数据类型:VARCHAR, TEXT
    • Redis 数据类型:String
  • Set

    • Java 数据结构:Set<T>(如 HashSet<String>
    • MySQL 数据类型:MySQL 没有直接的集合类型,但是可以使用多个字段或表来表示一个集合。
    • Redis 数据类型:Set(无序且元素唯一)
  • List

    • Java 数据结构:List<T>(如 ArrayList<String>
    • MySQL 数据类型:同样没有直接对应的集合类型,可能使用多个字段或关系表来实现。
    • Redis 数据类型:List
  • Hash

    • Java 数据结构:Map<K,V>(如 HashMap<String, String>
    • MySQL 数据类型:可以使用一行记录,其中包含多个列来表示一个哈希表。
    • Redis 数据类型:Hash
  • Sorted Set(有序集合)

    • Java 数据结构:可以使用带有比较器的 Set<T> 或者自定义逻辑来排序。
    • MySQL 数据类型:没有直接对应的集合类型,但可以通过添加额外的索引或者排序查询实现类似的功能。
    • Redis 数据类型:Sorted Set

需要注意的是,在 Redis 中存储的数据都是二进制安全的字符串,即使你存储的是数字或者布尔值,它们也会以字符串的形式存储。而 Java 和 MySQL 中的数据类型更加丰富,包括整型、浮点型、布尔型等,这些都是 Redis 不直接支持的。

相关推荐
之歆7 分钟前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(下)
开发语言·前端·javascript·ecmascript
risc1234569 分钟前
python 的字符串前缀
开发语言·python
小程故事多_809 分钟前
Agent Loop 核心突破,上下文压缩四大流派,重新定义窗口资源利用率
java·开发语言·人工智能
如竟没有火炬17 分钟前
字符串相乘——int数组转字符串
开发语言·数据结构·python·算法·leetcode·深度优先
吃好睡好便好21 分钟前
在Matlab中绘制三维等高线图
开发语言·python·学习·算法·matlab·信息可视化
天若有情67326 分钟前
自制C++万能字符串流式库 formort.h|对标标准库endl,零拷贝链式拼接神器
开发语言·c++
神仙别闹32 分钟前
基于Java+MySQL实现(GUI)医院管理系统
java·mysql·oracle
njsgcs42 分钟前
制作solidworks插件 装配体导出展开耗时分析
开发语言·c#·solidworks
C137的本贾尼42 分钟前
别怕异步:`async` 和 `await` 的简单理解
开发语言·python
njsgcs1 小时前
c# solidworks 标注攻牙
开发语言·c#·solidworks