oksice 2021-12-06 15:25 采纳率: 75%
浏览 40
已结题

JAVA按不同口径进行查询,并按顺序优先级返回,怎么处理返回比较有效

我感觉用 if + return 比较死板,但结果又不是一个变量不好使用switch case。测试代码如下:

public Map GetNbrStaffInfo(Map params) throws Exception {
  Map retMap = new HashMap();
  // 0查询成功,1查询失败
  retMap.put("code", "0");
  retMap.put("msg", "成功");
  //口径1
  String sql1 = “xxxxxxxxxx”;
  List<Map<String, String>> list1= DBUtil.getSimpleQuery().queryForMapListBySql(sql1,new String[] {参数});
 if (!ListUtil.isEmpty(list1)){
    retMap.put("staff_code",list1.get(0).get("staff_code"));
    retMap.put("staff_name",list1.get(0).get("staff_name"));
    return retMap;
  }
  //口径2
  String sql2 = “yyyyyyyyyy”;
  List<Map<String, String>> list2= DBUtil.getSimpleQuery().queryForMapListBySql(sql1,new String[] {参数});
 if (!ListUtil.isEmpty(list1)){
    retMap.put("staff_code",list2.get(0).get("staff_code"));
    retMap.put("staff_name",list2.get(0).get("staff_name"));
    return retMap;
  }
  //口径3
  String sql3 = “zzzzzzzzzz”;
  List<Map<String, String>> list3= DBUtil.getSimpleQuery().queryForMapListBySql(sql1,new String[] {参数});
 if (!ListUtil.isEmpty(list1)){
    retMap.put("staff_code",list3.get(0).get("staff_code"));
    retMap.put("staff_name",list3.get(0).get("staff_name"));
    return retMap;
  }
  //口径4
  String sql3 = “wwwwwww”;
  List<Map<String, String>> list4= DBUtil.getSimpleQuery().queryForMapListBySql(sql1,new String[] {参数});
   if (!ListUtil.isEmpty(list1)){
    retMap.put("staff_code",list4.get(0).get("staff_code"));
    retMap.put("staff_name",list4.get(0).get("staff_name"));
    return retMap;
  }
    retMap.put("code","1");
    retMap.put("msg","查无结果");
    retMap.put("staff_code","");
    retMap.put("staff_name","");
    return retMap;
}
  • 写回答

3条回答 默认 最新

  • qq_39900047 2021-12-06 15:42
    关注

    public Map GetNbrStaffInfo(Map params) throws Exception {
    Map retMap = new HashMap();
    // 0查询成功,1查询失败
    retMap.put("code", "0");
    retMap.put("msg", "成功");
    List<Map<String, String>> list1= findBySql(“xxxxxxxxxx”,new String[] {参数})
    if (ListUtil.isEmpty(list1)){
    list1= findBySql(“yyyyyyyyyy”,new String[] {参数})
    ListUtil.isEmpty(list1){
    list1= findBySql(“zzzzzzzzzz”,new String[] {参数})
    if(ListUtil.isEmpty(list1)){
    list1= findBySql(“wwwwww”,new String[] {参数})
    }
    }
    }
    if(ListUtil.isEmpty(list1)){
    retMap.put("staff_code",list1.get(0).get("staff_code"));
    retMap.put("staff_name",list1.get(0).get("staff_name"));
    return retMap;
    }
    retMap.put("code","1");
    retMap.put("msg","查无结果");
    retMap.put("staff_code","");
    retMap.put("staff_name","");
    return retMap;
    }
    public List<Map<String, String>> findBySql(String sql ,String[] arrys){
    return DBUtil.getSimpleQuery().queryForMapListBySql(sql,arrys));
    }

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 5月5日
  • 已采纳回答 4月27日
  • 创建了问题 12月6日

悬赏问题

  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘
  • ¥15 perl MISA分析p3_in脚本出错
  • ¥15 k8s部署jupyterlab,jupyterlab保存不了文件
  • ¥15 ubuntu虚拟机打包apk错误
  • ¥199 rust编程架构设计的方案 有偿
  • ¥15 回答4f系统的像差计算
  • ¥15 java如何提取出pdf里的文字?