MyBatis-Plus之通用枚举

news/2025/2/21 5:15:30

MyBatis-Plus之通用枚举

前言

MyBatis-Plus中提供了通用枚举,简单来说就是将数据库中的某一字段的代替的含义转换成真实的含义将数据展示给用户,用户在存储时也会将真实值转换成代替的数字存入到数据库中。举个例子:用户性别在数据库中存储为1(表示男)、2(表示女)。在读取数据库的数据时就会自动将1、2值转换为男或女,返回给前端。

这样做是可以有效地节省数据库的存储空间。下面我们来看看枚举的使用方式~

MyBatis官方文档讲解的MyBatisPlus枚举使用

官方文档讲MyBatisPlus的枚举的地址:https://www.baomidou.com/pages/8390a4/#%E6%AD%A5%E9%AA%A41-%E5%A3%B0%E6%98%8E%E9%80%9A%E7%94%A8%E6%9E%9A%E4%B8%BE%E5%B1%9E%E6%80%A7

MyBatisPlus的通用枚举解决了繁琐的配置,可以做到让 mybatis 优雅的使用枚举属性! 从MyBatisPlus的 3.5.2 版本开始只需完成 步骤1: 声明通用枚举属性 即可使用。

步骤1: 声明通用枚举属性

方式一: 使用 @EnumValue 注解枚举属性 完整示例(opens new window)

public enum GradeEnum {

    PRIMARY(1, "小学"),  SECONDORY(2, "中学"),  HIGH(3, "高中");

    GradeEnum(int code, String descp) {
        this.code = code;
        this.descp = descp;
    }

    @EnumValue//标记数据库存的值是code
    private final int code;
    //。。。
}

方式二: 枚举属性,实现 IEnum 接口如下:

public enum AgeEnum implements IEnum<Integer> {
    ONE(1, "一岁"),
    TWO(2, "二岁"),
    THREE(3, "三岁");

    private int value;
    private String desc;

    @Override
    public Integer getValue() {
        return this.value;
    }
}

实体属性使用枚举类型(方式一和方式二都要做这一步的,age演示的是使用IEnum接口的枚举处理,grade使用的是原生枚举)

public class User {
    /**
     * 名字
     * 数据库字段: name varchar(20)
     */
    private String name;

    /**
     * 年龄,IEnum接口的枚举处理
     * 数据库字段:age INT(3)
     */
    private AgeEnum age;


    /**
     * 年级,原生枚举(带{@link com.baomidou.mybatisplus.annotation.EnumValue}):
     * 数据库字段:grade INT(2)
     */
    private GradeEnum grade;
}

步骤2: 配置扫描通用枚举

  • 注意!! 从 3.5.2 开始无需配置
  • 注意!! spring mvc 配置参考,安装集成 MybatisSqlSessionFactoryBean 枚举包扫描,spring boot 例子配置如下:

示例工程:

👉 mybatisplus-spring-boot(opens new window)

方式一:仅配置指定包内的枚举类使用 MybatisEnumTypeHandler

配置文件 resources/application.yml

mybatis-plus:
    # 支持统配符 * 或者 ; 分割。这里写的是使用了@EnumValue的枚举的包名或者实现了IEnum接口的枚举的包名
    typeEnumsPackage: com.baomidou.springboot.entity.enums
  ....

当添加这个配置后,mybatis-plus 提供的 MybatisSqlSessionFactoryBean 会自动扫描包内合法的枚举类(使用了 @EnumValue 注解,或者实现了 IEnum 接口),分别为这些类注册使用 MybatisEnumTypeHandler

换句话说,只有指定包下的枚举类会使用新的 TypeHandler。其他包下,或者包内没有做相关改造的枚举类,仍然会使用 mybatis 的 DefaultEnumTypeHandler。

方式二:直接指定 DefaultEnumTypeHandler

此方式用来 全局 修改 mybatis 使用的 EnumTypeHandler。

配置文件 resources/application.yml

mybatis-plus:
    # 修改 mybatis 的 DefaultEnumTypeHandler
    configuration:
        default-enum-type-handler: com.baomidou.mybatisplus.core.handlers.MybatisEnumTypeHandler

自定义配置类 MybatisPlusAutoConfiguration

@Configuration
public class MybatisPlusAutoConfiguration {

    @Bean
    public MybatisPlusPropertiesCustomizer mybatisPlusPropertiesCustomizer() {
        return properties -> {
            GlobalConfig globalConfig = properties.getGlobalConfig();
            globalConfig.setBanner(false);
            MybatisConfiguration configuration = new MybatisConfiguration();
            configuration.setDefaultEnumTypeHandler(MybatisEnumTypeHandler.class);
            properties.setConfiguration(configuration);
        };
    }
}

如何序列化枚举值为前端返回值?

可以使用Jackson、或者Fastjson都行。使用Jackson可以使用下面的重写 toString 方法或者注解处理来达到告诉框架返回给前端的内容都行。使用Fastjson你就得重写toString方法了,可以使用下面的全局处理方式或者局部处理方式来做都行。

Jackson

一、重写 toString 方法
springboot
    @Bean
    public Jackson2ObjectMapperBuilderCustomizer customizer(){
        return builder -> builder.featuresToEnable(SerializationFeature.WRITE_ENUMS_USING_TO_STRING);
    }
ackson
    ObjectMapper objectMapper = new ObjectMapper();
    objectMapper.configure(SerializationFeature.WRITE_ENUMS_USING_TO_STRING, true);

以上两种方式任选其一,然后在枚举中复写 toString 方法,返回那个你要展示给前端的值,即可.

二、注解处理
public enum GradeEnum {

    PRIMARY(1, "小学"),  SECONDORY(2, "中学"),  HIGH(3, "高中");

    GradeEnum(int code, String descp) {
        this.code = code;
        this.descp = descp;
    }

    @EnumValue
  	@JsonValue	//标记响应json值
    private final int code;
}

Fastjson

一、重写 toString 方法
全局处理方式
    FastJsonConfig config = new FastJsonConfig();
    config.setSerializerFeatures(SerializerFeature.WriteEnumUsingToString);
局部处理方式
    @JSONField(serialzeFeatures= SerializerFeature.WriteEnumUsingToString)
    private UserStatus status;

以上两种方式任选其一,然后在枚举中复写 toString 方法即可.

例子

1. 导MyBatisPlus的包

2. 定义枚举类

image-20230714144245743

3. 扫描

image-20230714144529823

4. 在实体类里面使用枚举

image-20230714144753627

具体例子:

1. 导包

image-20230714145921890

2. 定义枚举类

image-20230714150104186

3. 扫描

image-20230714150501185

4. 在实体类里面使用枚举

image-20230714150545154

5. 测试

我们先看看测试的环境哈!

image-20230714150638825

image-20230714150729937

image-20230714150830780

好了,来演示:

数据库原来是这样的:

image-20230714151023641

image-20230714150950970

image-20230714151005778

执行后,我们看到孙悟空加进来了,且status被成功变为了1,即实习对应的值。

image-20230714151106722

我们看看输入,数字是不是可行。

image-20230714151225575

image-20230714151239632

image-20230714151251781

看到,一样是可行的。且前端展示的时候,也是把我们要展示的字段展示出来了。

展示代码如下:

image-20230714151343315

image-20230714151418019

优化前端展示:

image-20230714151536063

效果:

image-20230714151622961

image-20230714151651087

image-20230714151638647

上面的下拉就相当于是:你选择哪个选项,然后就把那个选项对应的value值给作为那个status变量的值了,然后传给后端,后端看到是1,存到数据库里面就是1,展示给前端的时候,就显示1对应的值,即“实习”


http://www.niftyadmin.cn/n/5860183.html

相关文章

JavaScript 前端面试 2(DOM、BOM)

三、DOM常见的操作有哪些 创建、删除、查询、更新节点&#xff08;用类似数据库的操作来讲就是对节点的增删改查&#xff09;&#xff0c;节点可以是元素&#xff08;element&#xff09;、文本&#xff08;text&#xff09;、注释&#xff08;comment&#xff09;等等。 1&a…

Vue.js 入门指南:从基础到实战

Vue.js 是一款流行的渐进式 JavaScript 框架,广泛用于构建交互式 Web 界面。它具有简单易学、轻量级、高性能的特点,适合前端新手入门。本文将从 Vue 的基本概念入手,详细介绍 Vue 的生命周期及常见用法,帮助你快速上手 Vue 开发 官网:https://cn.vuejs.org/ 1. Vue.js 介…

智能体(AI Agent、Deepseek、硅基流动)落地实践Demo——借助大模型生成报表,推动AI赋能企业决策

文章目录 一、 引言二、 系统设计与技术细节2.1 系统架构2.2 核心组件说明 三、 Demo 代码推荐博客&#xff1a; 四、输出年度营销报告1. 总销售额 根据提供的数据&#xff0c;年度总销售额为&#xff1a;740.0。2. 各产品销售额3. 各地区销售额4. 各产品在各地区的销售情况 分…

马斯克放出AI核弹:Grok 3干碎OpenAI

马斯克放出AI核弹&#xff1a;Grok 3干碎OpenAI&#xff01;这场厮杀太刺激了… 凌晨三点的发布会现场&#xff0c;马斯克抖了抖西装下摆&#xff0c;对着镜头咧嘴一笑&#xff1a;“现在&#xff0c;是时候让AI世界重新洗牌了。” 他身后的屏幕突然炸开刺目蓝光——Grok 3正式…

网络安全试题

ciw网络安全试题 &#xff08;1&#xff09;&#xff08;单选题&#xff09;使网络服务器中充斥着大量要求回复的信息&#xff0c;消耗带宽&#xff0c;导致网络或系统停止正常服务&#xff0c;这属于什么攻击类型? A、拒绝服务 B、文件共享 C、BIND漏洞 D、远程过程调用 &a…

Linux 文件与目录命令学习记录

在 Linux 系统的学习与使用过程中&#xff0c;对文件和目录的操作是极为基础且重要的部分。熟练掌握相关命令&#xff0c;能够高效地管理文件系统&#xff0c;提升工作效率。以下是我对 Linux 文件与目录命令的详细学习记录。 一、文件 & 目录命令 1. mkdir 命令 作用&…

Elasticsearch 混合搜索 - Hybrid Search

作者&#xff1a;来自 Elastic Valentin Crettaz 了解混合搜索、Elasticsearch 支持的混合搜索查询类型以及如何制作它们。 本文是三篇系列文章中的最后一篇&#xff0c;深入探讨了向量搜索&#xff08;又称语义搜索&#xff09;的复杂性以及它在 Elasticsearch 中的实现方式。…

QT QLabel加载图片等比全屏自适应屏幕大小显示

最近在工作项目中,遇到一个需求: 1.使用QLabel显示一张图片; 2.当点击这个QLabel时,需要全屏显示;但不能改变原来的尺寸; 3.当点击放大后的QLabel时,恢复原有大小. 于是乎,就有了本篇博客,介绍如何实现这样的功能. 一、演示效果 在一个水平布局中&#xff0c;添加两个Lable用…