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

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

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

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());
    }
相关推荐
阿里嘎多哈基米35 分钟前
SQL 层面行转列
数据库·sql·状态模式·mapper·行转列
抠脚学代码44 分钟前
Ubuntu Qt x64平台搭建 arm64 编译套件
数据库·qt·ubuntu
jakeswang1 小时前
全解MySQL之死锁问题分析、事务隔离与锁机制的底层原理剖析
数据库·mysql
Heliotrope_Sun1 小时前
Redis
数据库·redis·缓存
一成码农2 小时前
MySQL问题7
数据库·mysql
吃饭最爱2 小时前
JUnit技术的核心和用法
数据库·oracle·sqlserver
专注API从业者2 小时前
Python/Java 代码示例:手把手教程调用 1688 API 获取商品详情实时数据
java·linux·数据库·python
雨落Liy2 小时前
SQL 函数从入门到精通:原理、类型、窗口函数与实战指南
数据库·sql
Kt&Rs3 小时前
MySQL复制技术的发展历程
数据库·mysql
小小菜鸡ing3 小时前
pymysql
java·服务器·数据库