开发中遇到问题

今天在生产中遇到了并发导致数据null的问题:

代码:

 public static String getAddressName(String type, String code) {
      /*String strReturn = "";
         ExeSQL exeSql = new ExeSQL();
         String sql = "select placeName from ldaddress where placeType='" + type
                 + "' and placeCode='" + code + "'";
         strReturn = exeSql.getOneValue(sql);
         return strReturn;*/
//     缓存减少查询次数
      if(addressName == null || !addressName.containsKey( type + "_" + code )){
       addressName = new HashMap<String, String>();
       String sql = "select placeType,placeCode,placeName from ldaddress";
       ExeSQL exesql = new ExeSQL();
       SSRS ssrs = exesql.execSQL(sql);
       String key = null;
       String value = null;
       for (int i = 1; i <= ssrs.getMaxRow(); i++) {
    key = ssrs.GetText(i, 1) + "_" + ssrs.GetText(i, 2);
    value = ssrs.GetText(i, 3);
    addressName.put(key, value);
   }
      }
      return addressName.get( type + "_" + code );
//  end
    }

 

问题解决:

public static String getAddressName(String type, String code) {
  /*
   * String strReturn = ""; ExeSQL exeSql = new ExeSQL(); String sql =
   * "select placeName from ldaddress where placeType='" + type +
   * "' and placeCode='" + code + "'"; strReturn =
   * exeSql.getOneValue(sql); return strReturn;
   */
  // start  缓存减少查询次数
  synchronized (addressName) {
   if (!addressName.containsKey(type + "_" + code)) {
    String sql = "select placeType,placeCode,placeName from ldaddress";
    ExeSQL exesql = new ExeSQL();
    SSRS ssrs = exesql.execSQL(sql);
    String key = null;
    String value = null;
    for (int i = 1; i <= ssrs.getMaxRow(); i++) {
     key = ssrs.GetText(i, 1) + "_" + ssrs.GetText(i, 2);
     value = ssrs.GetText(i, 3);
     addressName.put(key, value);
    }
   }
  }
  return addressName.get(type + "_" + code);
  // end
 }

转载于:https://www.cnblogs.com/gtaxmjld/p/5238467.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值