【Spring连载】使用Spring Data访问Redis(七)----Hash Mapping

【Spring连载】使用Spring Data访问Redis(七)----Hash Mapping

你可以使用Redis中的各种数据结构来存储数据。Jackson2JsonRedisSerializer可以转换JSON格式的对象。理想情况下,通过使用plain键,JSON可以存储为值。通过使用Redis hashes,你可以实现更复杂的结构化对象映射。Spring Data Redis提供了各种将数据映射到哈希的策略(取决于用例):

  • 使用HashOperations和序列化程序进行直接映射
  • 使用Redis Repositories
  • 使用HashMapper和HashOperations

一、Hash Mappers

哈希映射器是将对象和Map<K, V>来回映射的转换器。HashMapper用于Redis Hashes。

有多种实施方式可供选择:

  • BeanUtilsHashMapper:使用Spring的BeanUtils。
  • ObjectHashMapper:使用对象到哈希映射
  • Jackson2HashMapper:使用FasterXML Jackson。

以下示例展示了一种实现哈希映射的方法:

java 复制代码
public class Person {
  String firstname;
  String lastname;

  // ...
}

public class HashMapping {

  @Resource(name = "redisTemplate")
  HashOperations<String, byte[], byte[]> hashOperations;

  HashMapper<Object, byte[], byte[]> mapper = new ObjectHashMapper();

  public void writeHash(String key, Person person) {

    Map<byte[], byte[]> mappedHash = mapper.toHash(person);
    hashOperations.putAll(key, mappedHash);
  }

  public Person loadHash(String key) {

    Map<byte[], byte[]> loadedHash = hashOperations.entries("key");
    return (Person) mapper.fromHash(loadedHash);
  }
}

二、Jackson2HashMapper

Jackson2HashMapper通过使用FasterXML Jackson为域对象(domain objects)提供Redis Hash映射。Jackson2HashMapper可以将顶级属性映射为哈希字段名,还可以选择展平(flatten)结构。简单类型映射到简单值。复杂类型(嵌套对象、集合、映射等)表示为嵌套JSON。

扁平化(Flattening)为所有嵌套属性创建单独的哈希条目,并尽可能将复杂类型解析为简单类型。

举例,有以下类及其包含的数据结构:

java 复制代码
public class Person {
  String firstname;
  String lastname;
  Address address;
  Date date;
  LocalDateTime localDateTime;
}

public class Address {
  String city;
  String country;
}

下表展示了前面类中的数据如何在一般映射中显示:
表 1. 一般映射

Hash Field Value
firstname Jon
lastname Snow
address { "city" : "Castle Black", "country" : "The North" }
date 1561543964015
localDateTime 2018-01-02T12:13:14

下表展示了上述类中的数据在扁平(flat)映射中的显示方式:
表 2. Flat映射

Hash Field Value
firstname Jon
lastname Snow
address.city Castle Black
address.country The North
date 1561543964015
localDateTime 2018-01-02T12:13:14

扁平化要求所有属性名称不干扰JSON路径。使用展平(flattening)时,不支持在映射key中使用点或括号,也不支持将其用作property名称。生成的哈希无法映射回对象。

java.util.Date 和 java.util.Calendar用毫秒表示。如果jackson-datatype-jsr310在类路径上,JSR-310日期/时间类型将序列化为它们的toString形式。

相关推荐
黑客影儿38 分钟前
Java技术总监的成长之路(技术干货分享)
java·jvm·后端·程序人生·spring·tomcat·maven
lssjzmn5 小时前
🚀如何基于Redis的ZSet数据结构设计一个通用的,简单的,可靠的延迟消息队列,以RedisTemplate为例
redis
Miraitowa_cheems5 小时前
LeetCode算法日记 - Day 15: 和为 K 的子数组、和可被 K 整除的子数组
java·数据结构·算法·leetcode·职场和发展·哈希算法
jakeswang6 小时前
应用缓存不止是Redis!——亿级流量系统架构设计系列
redis·分布式·后端·缓存
.Shu.8 小时前
Redis zset 渐进式rehash 实现原理、触发条件、执行流程以及数据一致性保障机制【分步源码解析】
数据库·redis·缓存
君不见,青丝成雪8 小时前
大数据技术栈 —— Redis与Kafka
数据库·redis·kafka
悟能不能悟8 小时前
排查Redis数据倾斜引发的性能瓶颈
java·数据库·redis
切糕师学AI8 小时前
.net core web程序如何设置redis预热?
redis·.netcore
Derek_Smart8 小时前
Java线程死亡螺旋:解析与预防策略
java·spring·性能优化
Mi_Manchikkk8 小时前
Java高级面试实战:Spring Boot微服务与Redis缓存整合案例解析
java·spring boot·redis·缓存·微服务·面试