在枚举类中“优雅地”使用枚举处理器

使用枚举类的一大好处就是,代码易懂,方便自己或他人维护。如,枚举状态、异常等。

下面有两个类(枚举类和实体类):

java 复制代码
package com.zhang.enums;

import lombok.Getter;

/**
 * @Author lgz
 * @Description
 * @Date 2023/9/30.
 */

@Getter
public enum  GlobalEnums {

    NORMAL(0,"正常"),
    FROZEN(1,"已删除"),
    ;
    // @EnumValue
    // 这个注解,相当于告诉mp,这个字段对应数据库的字段,往数据库中写
    private final int number;
    private final String description;


    GlobalEnums(int number, String description) {
        this.number = number;
        this.description = description;
    }
}

Animal类中有一个用户状态字段:

java 复制代码
package com.zhang.entity;

@Data
public class Animal implements Serializable{


    // 其余字段...


    @ApiModelProperty(value = "删除状态(0-正常,1-已删除,2-已冻结)")
    private Integer delFlag;


}

应用如下:

第一步:把字段的类型改成我们的enum类,如下:

java 复制代码
package com.zhang.entity;

@Data
public class Animal implements Serializable{


    // 其余字段...


    @ApiModelProperty(value = "删除状态(0-正常,1-已删除)")
    private GlobalEnums delFlag;


}

第二步:在枚举类中,在对应的字段是添加注解@EnumValue、 @JsonValue,如下:

java 复制代码
package com.zhang.enums;

import com.baomidou.mybatisplus.annotation.EnumValue;
import com.fasterxml.jackson.annotation.JsonValue;
import lombok.Getter;

/**
 * @Author lgz
 * @Description
 * @Date 2023/9/30.
 */

@Getter
public enum  GlobalEnums {

    NORMAL(0,"正常"),
    FROZEN(1,"已删除"),
    ;
     @EnumValue
    // @EnumValue相当于告诉mp,这个字段对应数据库的字段,往数据库中写
    private final int number;
     @JsonValue
     // @JsonValue加在对应的字段是会显示对应的信息,
     // 比如,如果加到"number"上就返回个数字给前端,
     // 加到"description"上就返回"字符串",
     // 如果不使用这个注解就返回"NORMAL"或"FROZEN"给前端。
    private final String description;


    GlobalEnums(int number, String description) {
        this.number = number;
        this.description = description;
    }
}

第三步:在properties或者yml文件中添加如下配置:

bash 复制代码
mybatis-plus.configuration.default-enum-type-handler=com.baomidou.mybatisplus.extension.handlers.MybatisEnumTypeHandler

第四步:测试:

java 复制代码
    @GetMapping(value = "/listOfAll")
    public Result<?> listOfAll() {

        return Result.OK(animalService.listAnimals());
    }
相关推荐
Zfox_3 小时前
Redis:Hash数据类型
服务器·数据库·redis·缓存·微服务·哈希算法
陈丹阳(滁州学院)5 小时前
若依添加添加监听容器配置(删除键,键过期)
数据库·oracle
远方16096 小时前
14-Oracle 23ai Vector Search 向量索引和混合索引-实操
数据库·ai·oracle
GUIQU.7 小时前
【Oracle】数据仓库
数据库·oracle
恰薯条的屑海鸥8 小时前
零基础在实践中学习网络安全-皮卡丘靶场(第十六期-SSRF模块)
数据库·学习·安全·web安全·渗透测试·网络安全学习
咖啡啡不加糖8 小时前
Redis大key产生、排查与优化实践
java·数据库·redis·后端·缓存
曼汐 .8 小时前
数据库管理与高可用-MySQL高可用
数据库·mysql
2301_793102498 小时前
Linux——MySql数据库
linux·数据库
喵叔哟8 小时前
第4章:Cypher查询语言基础
数据库
刘 大 望8 小时前
数据库-联合查询(内连接外连接),子查询,合并查询
java·数据库·sql·mysql