飞翔的小野鸭 2017-12-22 17:30 采纳率: 34.9%
浏览 5595
已结题

redis查找和更新的缓存问题

1.首先先进行查找uuid为123的用户

    @GetMapping("/{uuid}")
    public User get(@PathVariable String uuid) {
        return userService.findByUuid(uuid);
    }

        @Cacheable(value = "userInfo", key = "'findByUuid-' + #uuid")
    @Override
    public User findByUuid(String uuid) {
        return userDao.findOne(uuid);
    }

能确保uuid为123的用户查找得出来而且查找到的用户也存入缓存.(多查找几次控制台也只显示一次的sql语句)

2.更新uuid为123的用户

    @PutMapping("/{uuid}")
    public String update(@PathVariable String uuid,@RequestBody User updateUser){
        User user = userService.findByUuid(uuid);
        user.setUserName(updateUser.getUserName());
        user.setPassword(updateUser.getPassword());
        user.setAge(updateUser.getAge());
        user.setPhone(updateUser.getPhone());
        userService.save(user);
        return "success";
    }

        @CacheEvict(value = "userInfo", key = "'findByUuid-' + #user.getUuid()")
    @Override
    public User save(User user) {
        return userDao.save(user);
    }

更新时执行却又执行了select ,按道理来说findByUuid(123)应该被存入缓存,而不会打印select 语句才对啊.
以下是更新uuid为123时控制台打印的语句

   Hibernate: 
    select
        user0_.uuid as uuid1_0_0_,
        user0_.age as age2_0_0_,
        user0_.password as password3_0_0_,
        user0_.phone as phone4_0_0_,
        user0_.user_name as user_nam5_0_0_ 
    from
        user user0_ 
    where
        user0_.uuid=?
   Hibernate: 
    update
        user 
    set
        age=?,
        password=?,
        phone=?,
        user_name=? 
    where
        uuid=?
  • 写回答

6条回答 默认 最新

  • qwe530660883 2017-12-23 02:52
    关注

    更新时执行却又执行了select ,按道理来说findByUuid(123)应该被存入缓存,而不会打印select 语句才对啊.
    以下是更新uuid为123时控制台打印的语句

    评论

报告相同问题?

悬赏问题

  • ¥15 fluent的在模拟压强时使用希望得到一些建议
  • ¥15 STM32驱动继电器
  • ¥15 Windows server update services
  • ¥15 关于#c语言#的问题:我现在在做一个墨水屏设计,2.9英寸的小屏怎么换4.2英寸大屏
  • ¥15 模糊pid与pid仿真结果几乎一样
  • ¥15 java的GUI的运用
  • ¥15 Web.config连不上数据库
  • ¥15 我想付费需要AKM公司DSP开发资料及相关开发。
  • ¥15 怎么配置广告联盟瀑布流
  • ¥15 Rstudio 保存代码闪退