方法一:
@Cacheable(value="aboutUser",key = "'testGetAllUser'")
@Override
public List<User> getAllUser() {
return iUserDao.selectAllUser();
}
@CachePut(value = "aboutUser", key = "'user_'+#user.id")
@Override
public User insertUser(User user) {
//进行了主键回填
iUserDao.insertUser(user);
return user;
}
在插入页面里,设置@CachePut
在插入操作的Controller层里,加入中间两条(比较笨的方法)
@RequestMapping(value = "/addUser", method = RequestMethod.POST)
public void addUser(User user, HttpServletResponse response) throws Exception {
System.out.println("******addUser********");
User result = userService.insertUser(user);
if (result.getId() != 0) {
**List<User> list = userService.getAllUser();
redisTemplate.opsForValue().set("testGetAllUser", list, 1, TimeUnit.SECONDS);**
response.getWriter().print("OK");
} else {
response.getWriter().print("FAIL");
}
}
方法二:
@Cacheable(value="aboutUser",key = "'testGetAllUser'")
@Override
public List<User> getAllUser() {
return iUserDao.selectAllUser();
}
@CacheEvict(value= "aboutUser", key="'testGetAllUser'")
@Override
public User insertUser(User user) {
//进行了主键回填
iUserDao.insertUser(user);
return user;
}
两个方法的key写一样的,就可以写入读取同一个缓存,这里也可以在@CacheEvict里面加入一个beforeInvocation = ture,但是在这里加不加,效果一样,所以就没加。(这个的意思是在方法调用之前就清空缓存的意思)
两个方法优缺点分析(个人理解):方法一代码多了几个,但是可以提前缓存,缓存根据ID查询的信息
方法二呢,就是少输入点代码。
有说错的地方,望指出