将查询出来数据中相对应的字段根据枚举类更改为其中文内容

简介: 将查询出来数据中相对应的字段根据枚举类更改为其中文内容

🐓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("对应字段名")))


相关文章
|
3月前
|
SQL 关系型数据库 MySQL
MySQL根据某个字段包含某个字符串或者字段的长度情况更新另一个字段的值,如何写sql
MySQL根据某个字段包含某个字符串或者字段的长度情况更新另一个字段的值,如何写sql
214 0
|
7月前
|
Java
【Java】— —实现人物对象的增、删、改、查(注:对象的删除以逻辑删除为主,在person类中设置“删除状态字段”,字删除该字段时,将状态改为有效。)
【Java】— —实现人物对象的增、删、改、查(注:对象的删除以逻辑删除为主,在person类中设置“删除状态字段”,字删除该字段时,将状态改为有效。)
|
缓存 NoSQL Java
如何给多参数接口添加缓存(根据方法名字+参数名生成对应的key)
如何给多参数接口添加缓存(根据方法名字+参数名生成对应的key)
222 0
如何给多参数接口添加缓存(根据方法名字+参数名生成对应的key)
|
Oracle 关系型数据库
oracle按code编码长度查询代码展现层级关系(给字段前加空格)
学习oracle按code编码长度查询代码展现层级关系(给字段前加空格)
155 0
oracle按code编码长度查询代码展现层级关系(给字段前加空格)
|
关系型数据库 MySQL
mysql更新一个表中的姓名字段,随机取出姓,名部分截取该表中另外一个字段拼接...
mysql更新一个表中的姓名字段,随机取出姓,名部分截取该表中另外一个字段拼接...
255 0
mysql更新一个表中的姓名字段,随机取出姓,名部分截取该表中另外一个字段拼接...
修改某个数据列的名字或者数据类型|学习笔记
快速学习修改某个数据列的名字或者数据类型
181 0
|
API
@JsonView 处理返回值,实现接口返回想要的字段
@JsonView 处理返回的json ,实现返回需要的字段
1666 0
|
PHP
Laravel返回不重复的某个字段信息列表
->groupBy('brand_id') ->pluck('brand_id');  学习交流群:364976091
2055 0