java:缓存 json格式

以下是修改后的代码:

import org.apache.ibatis.session.SqlSession;

import org.springframework.data.redis.core.RedisTemplate;

import com.alibaba.fastjson.JSON;

import java.util.List;

import java.util.stream.Collectors;

import java.util.logging.Logger;

public class OfferingCacheWithMyBatisAndRedisTemplate {

private static final Logger logger = Logger.getLogger(OfferingCacheWithMyBatisAndRedisTemplate.class.getName());

private static final String REDIS_KEY = "Cache_key";

public static void main(String[] args) {

try (SqlSession sqlSession = MyBatisUtil.getSqlSessionFactory().openSession()) {

// 使用 MyBatis 查询数据库数据并获取列表

List<OfferingEntity> offeringList = sqlSession.selectList("mapper.OfferingMapper.selectOfferings");

RedisTemplate<String, String> redisTemplate = new RedisTemplate<>();

// 假设你已经正确配置了连接工厂

redisTemplate.setConnectionFactory(redisConnectionFactory);

offeringList.stream()

.forEach(offering -> {

String name = offering.getName();

boolean hasField = redisTemplate.opsForHash().hasKey(REDIS_KEY, name);

String cachedValue = hasField? (String) redisTemplate.opsForHash().get(REDIS_KEY, name) : null;

String jsonEntity = JSON.toJSONString(offering);

if (!hasField || (cachedValue!= null &&!cachedValue.equals(jsonEntity))) {

// 如果数据不同或者未缓存,更新缓存并记录日志

redisTemplate.opsForHash().put(REDIS_KEY, name, jsonEntity);

logger.info("Updated cache. Name: " + name);

}

});

sqlSession.commit();

} catch (Exception e) {

logger.severe("Error in cache update: " + e.getMessage());

}

}

// 假设的数据库实体类

static class OfferingEntity {

private String name;

private String code;

private String id;

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public String getCode() {

return code;

}

public void setCode(String code) {

this.code = code;

}

public String getId() {

return id;

}

public void setId(String id) {

this.id = id;

}

}

}

在这段代码中,将实体类转换为 JSON 格式字符串进行存储。当需要获取数据时,可以从缓存中取出 JSON 字符串,再转换回实体类对象进行使用。这样可以方便地存储和组装数据。

相关推荐
小张认为的测试1 分钟前
Liunx上Jenkins 持续集成 Java + Maven + TestNG + Allure + Rest-Assured 接口自动化项目
java·ci/cd·jenkins·maven·接口·testng
蘑菇丁31 分钟前
ansible批量生产kerberos票据,并批量分发到所有其他主机脚本
java·ide·eclipse
呼啦啦啦啦啦啦啦啦1 小时前
【Redis】持久化机制
java·redis·mybatis
我想学LINUX2 小时前
【2024年华为OD机试】 (A卷,100分)- 微服务的集成测试(JavaScript&Java & Python&C/C++)
java·c语言·javascript·python·华为od·微服务·集成测试
空の鱼7 小时前
java开发,IDEA转战VSCODE配置(mac)
java·vscode
P7进阶路8 小时前
Tomcat异常日志中文乱码怎么解决
java·tomcat·firefox
小丁爱养花9 小时前
Spring MVC:HTTP 请求的参数传递2.0
java·后端·spring
CodeClimb9 小时前
【华为OD-E卷 - 第k个排列 100分(python、java、c++、js、c)】
java·javascript·c++·python·华为od
等一场春雨9 小时前
Java设计模式 九 桥接模式 (Bridge Pattern)
java·设计模式·桥接模式