• 【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());
    
        }

    结果:

  • 相关阅读:
    教你如何在 Visual Studio 2013 上使用 Github
    如果你也会C#,那不妨了解下F#(1):F# 数据类型
    博客园主题美化
    适配器模式 实战
    mysql in 超过1000 解决方案
    shell: 循环日期+1
    sqoop export 报错:Got exception running Sqoop: org.kitesdk.data.DatasetNotFoundException: Descriptor location does not exist:
    git 回滚到执行版本,并推送到远程分支
    hive表增加字段,并指定字段位置
    微信抢红包架构设计
  • 原文地址:https://www.cnblogs.com/sxdcgaq8080/p/9562633.html
Copyright © 2020-2023  润新知