🐓1.通过mapper.xml文件中的内容使用case+when进行更换字段内容
SELECT case user_type when '101000' then '李明' when '101001' then '王丽' when '101002' then '王小黑' when '101003' then '王大黑' when '101004' then '超级大王' when '101005' then '小董' else '' end as '别称' from 表名
虽然简单但是不推荐,会增加sql的查询时间,建议使用第二种方法,在业务层进行处理
🐓2.创建对应枚举类
第一步创建枚举类
public enum UserType { Enum1("101000","李明"), Enum2("101001","王丽"), Enum3("101002","王小黑"), Enum4("101003","王大黑"), Enum6("101004","超级大王"), Enum7("101005","小董"); private String val; private String name; //生成get方法 UserType(String itemCode, String name) { this.val = itemCode; this.name = name; } public String getVal() { return val; } public String getName() { return name; } //创建根据val值进行获取name值的方法 public static String getUserTypeName(String val) { return Arrays.stream(UserType.values()) .filter(userType -> userType.getVal().equals(val)) .map(UserType::getName) .findFirst() .orElse(null); } }
第二步查询sql并查询相对应的字段的数据
//执行其相对应的dao层查询业务相关数据 List<Map<String, Object>> billList=chargeBillDao.findByBill(参数)
第三步进行遍历
//将返回内容重新遍历,然后通过枚举类中的方法进行内容的替换 billList.forEach(bill->bill.put("对应字段",UserType.getUserTypeName(bill.get("对应字段名")))