关于redis缓存踩的坑

bug 1:

    @Override
    @Cacheable(cacheManager = Constants.REDIS_LOCAL, keyGenerator = DigestKeyGenerator.class)
    public Map<Integer, Map<Integer, List<HouseRoomImageNewEntity>>> getHouseRoomPics(Integer cityId, List<Integer> houseIds, List<Integer> rooms) {

        QHouseRoomImageNewEntity qHouseRoomImageNewEntity = QHouseRoomImageNewEntity.houseRoomImageNewEntity;
        List<Predicate> where = new ArrayList<>();
        where.add(qHouseRoomImageNewEntity.cityId.eq(cityId));
        where.add(qHouseRoomImageNewEntity.houseId.in(houseIds));
        if (CollectionUtils.isNotEmpty(rooms)) {
            where.add(qHouseRoomImageNewEntity.totalRooms.in(rooms));
        }
        List<HouseRoomImageNewEntity> all = jpaQueryFactory.selectFrom(qHouseRoomImageNewEntity)
                .where(where.toArray(new Predicate[where.size()])).fetch();
        if (CollectionUtils.isNotEmpty(all)) {

            Map<Integer, Map<Integer, List<HouseRoomImageNewEntity>>> map = all.parallelStream().collect(Collectors.groupingBy(e -> e.getHouseId(), Collectors.groupingBy(f -> f.getTotalRooms()));

            return map;
        }

        return new HashMap<>();
    }

返回值类型是map,Map中的key类型都是integer,

但是缓存中默认的key是string类型的,所以造成的现象就是第一次是正确的,之后刷新的数据是错误的

修改:将map中的integer类型换成了string类型

bug 2:<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值