我感觉用 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,把所有口径都传入, 按照你这个口径排序,取第一条