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;
}

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));
}

既然返回的结果都是 staff_code 和 staff_name 为何不用一个接口就搞定呢
只是传入的SQL语句参数不同而已可以用MyBatis--SQL构建器写法来实现

直接一个sql,把所有口径都传入, 按照你这个口径排序,取第一条