【redis】spring boot中 使用redis hash 操作 --- 之 使用redis实现库存的并发有序操作...

示例:

@Autowired
    StringRedisTemplate redisTemplate;

    @Override
    public void dealRedis(Dealer dealer) {

        dealer = dao.findByUid(dealer.getUid());
        String tid = dealer.getTenementId();

        HashOperations<String, Object, Object> ofh = redisTemplate.opsForHash();

        Field[] declaredFields = dealer.getClass().getDeclaredFields();
        for (Field declaredField : declaredFields) {
            String name = declaredField.getName();
            if (name.equals("id") || name.equals("tid")){
                continue;
            }else {
                ofh.increment(tid,name,111);
            }
        }
        Map<Object, Object> entries = ofh.entries(tid);
        System.out.println("获取Map>>>>>>>>>>>>>>>>>>>>>>>>>>"+entries.toString());
        Set<Object> keys = ofh.keys(tid);
        System.out.println("获取KEY的SET>>>>>>>>>>>>>>>>>>>>>"+keys.toString());
        List<Object> values = ofh.values(tid);
        System.out.println("获取VALUES的LIST>>>>>>>>>>>>>>>>>>>>>"+values.toString());

        ofh.delete(tid,keys.toArray());
        System.out.println("删除成功>>>>>>>>>>>>>>>>>>>>>>>>>>");
        Map<Object, Object> entries2 = ofh.entries(tid);
        System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>"+entries2.toString());

        for (Object key : keys) {
            ofh.increment(tid,key,111);
        }
        Map<Object, Object> entries3 = ofh.entries(tid);
        System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>"+entries3.toString());


        for (Object key : keys) {
            ofh.increment(tid,key,-11);
        }
        Map<Object, Object> entries4 = ofh.entries(tid);
        System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>"+entries4.toString());

        ofh.delete(tid,keys.toArray());
        System.out.println("删除成功>>>>>>>>>>>>>>>>>>>>>>>>>>");


        for (Object key : keys) {
            ofh.increment(tid,key,-11);
        }
        Map<Object, Object> entries5 = ofh.entries(tid);
        System.out.println(">>>>>>>>>>>>>>>>>>>>>>>>>>"+entries5.toString());

    }

 

 

结果:

 

转载于:https://www.cnblogs.com/sxdcgaq8080/p/9562633.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值