MyBatis-Plus 自动赋值实体字段最佳实践指南

2025-07-24 20:50

本文主要是介绍MyBatis-Plus 自动赋值实体字段最佳实践指南,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与...

MyBatis-Plus(简称 MP)是 MyBatis 的增强工具包,提供了很多便利的功能,其中 自动赋值实体字段 是开发中非常常见的需求。本文将深入探讨 MyBatis-Plus 的自动赋值机制,并通过详细的 Java 代码和表格进行对比和解释,帮助大家更好地掌握这个功能。

1. MyBatis-Plus 自动赋值概述

MyBatis-Plus 提供了一种便捷的方式来自动填充实体对象中的字段,尤其是在处理一些常见的数据库操作时(如创建时间、更新时间等)。在进行数据插入、更新操作时,常常需要对某些字段进行自动填充,减少手动赋值的工作量,提升开发效率。

1.1 适用场景

  • 时间戳自动填充:如 createTimeupdateTime 等字段通常需要在插入或更新时自动填充为当前时间。
  • 用户信息填充:如 createByupdateBy 等字段通常需要在操作时自动填充当前操作用户。
  • 逻辑删除标识www.chinasem.cn如 isDeleted 字段,插入时自动填充 0,更新时填充 1 表示android删除。

1.2 自动填充的原理

MyBatis-Plus 的自动赋值字段主要通过 @TableField 注解与填充策略来实现。它通过配置特定的填充规则,使得在执行插入、更新操作时,某些字段能够自动填充。

1.3 填充策略

MyBatis-Plus 提供了四种常见的填充策略:

  • FieldFill.INSERT:在插入时填充
  • FieldFill.UPDATE:在更新时填充
  • FieldFill.INSERT_UPDATE:在插入和更新时都填充
  • FieldFill.DEFAULT:不指定填充策略,使用默认填充规则

2. 关键注解与配置

MyBatis-Plus 提供了两个关键注解用于自动赋值字段的配置:@TableField@TableId

2.1@TableField注解

@TableField 注解用于标识实体类中的字段,配合 fill 属性来定义自动填充的行为。通过 fill 属性,我们可以为字段指定填充策略。

示例:

@TableField(fill = FieldFill.INSERT)
private Date createTime;
@TableField(fill = FieldFill.INSERT_UPDATE)
private Date updateTime;
  • createTime 字段在插入时自动填充。
  • updateTime 字段在插入和更新时自动填充。

2.2@TableId注解

@TableId 注解用于指定实体类中的主键字段。在某些情况下,我们也可能需要对主键字段进行自动赋值。通常来说,MyBatis-Plus 会自动处理主键生成策略(如自增、UUID 等)。

示例:

@TableId(type = IdType.AUTO)
private Long id;

该配置表示主键 id 使用数据库自增。

2.3 配置填充策略

为了实现自动赋值,我们需要配置填充策略。填充策略可以在 Mapper 层通过实现 MetaObjectHandler 接口来指定。

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        this.strictInsertFill(metaObject, "createTime", Date.class, new Date()); // 插入时填充 createTime
        this.strictInsertFill(metaObject, "createBy", String.class, "admin");   // 插入时填充 createBy
    }
    @Override
    public void updateFill(MetaObject metaObject) {
        this.strictUpdateFill(metaObject, "updateTime", Date.class, new Date()); // 更新时填充 updateTime
        this.strictUpdateFill(metaObject, "updateBy", String.class, "admin");   // 更新时填充 updateBy
    }
}

MetaObjectHandler 是 MyBatis-Plus 提供的接口,用于处理自动填充的逻辑。通过实现该接口,我们可以在插入和更新时自定义字段的自动填充行为。

3. 使用实例python与代码解析

3.1 实体类示例

假设我们有一个 User 实体类,包含 id, username, createTime, updateTime 等字段,并希望在进行插入和更新时自动填充时间戳。

@Data
public class User {
    @TableId(type = IdType.AUTO)
    private Long id;
    private String username;
    @TableField(fill = FieldFill.INSERT)
    private Date createTime;
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;
}

3.2 Mapper 示例

在 Mapper 接口中,我们可以直接使用 MyBatis-Plus 提供的 updateById, insert 等方法。

@Mapper
public interface UserMapper extends BaseMapper<User> {
    // 自定义的数据库操作方法
}

3.3 自动赋值操作示例

@Service
public class UserService {
    @Autowired
    private UserMapper userMapper;
    public void addUser(User user) {
        // 自动填充的字段会被 MyBatis-Plus 处理
        userMapper.insert(user);
    }
    public void updateUser(User user) {
        // 自动填充的字段会被 MyBatis-Plus 处理
        userMapper.updateById(user);
    }
}

在上述示例中,createTimeupdateTime 会在插入和更新时自动填充。

4. 表格对比:不同填充策略行为

字段类型FieldFill.INSERTFieldFill.UPDwww.chinasem.cnATEFieldFill.INSERT_UPDATEFieldFill.DEFAULT
createTime仅在插入时填充不会填充会在插入和更新时填充根据默认策略,通常是 INSERT
updateTime不会填充仅在更新时填充会在插入和更新时填充根据默认策略,通常是 INSERT

通过表格,我们可以看到不同填充策略的行为区别。开发者可以根据业务需求来选择合适的填充策略。

5. 总结与最佳实践

5.1 自动赋值的优势

  • 减少重复代码:自动填充时间戳和用户信息等常见字段,避免手动赋值。
  • 提高代码可读性:通过注解和配置清晰表达字段填充逻辑,简化代码。
  • 保证数据一致性:自动填充保证了字段值的一致性,减少人为错误。

5.2 常见问题与解决方案

  • 填充不生效:请确保已正确配置 MetaObjectHandler,并且 @TableField(fill = FieldFill.xxx) 注解已加在正确的字段上。
  • 更新时覆盖:修改配置类MyMetaObjjsectHandler
  • strictUpdateFill(): 保留更新实体对象的原有值,只在字段为空时才会进行填充。
  • setFieldValByName(): 会强制覆盖实体对象字段的原有值,不论字段是否为空。
  • 主键策略问题:在使用 @TableId 注解时,需要明确指定主键生成策略(如 IdType.AUTO)。

5.3 最佳实践

  • 使用 MetaObjectHandler 配置全局的字段填充策略。
  • 避免在业务层手动设置常规字段(如时间戳、用户信息),通过自动填充来保证一致性。
  • 尽量避免过多的手动填充,自动赋值机制能有效减少错误和重复代码。

通过本文的学习,相信你对 MyBatis-Plus 自动赋值实体字段的使用有了更深入的理解。合理利用 MyBatis-Plus 提供的自动填充功能,可以大大提高开发效率并降低出错的概率。希望你在实际开发中能够得心应手地运用这些技巧

到此这篇关于MyBatis-Plus 自动赋值实体字段的文章就介绍到这了,更多相关mybatisplus自动赋值内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于MyBatis-Plus 自动赋值实体字段最佳实践指南的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1155475

相关文章

Python实现PDF按页分割的技术指南

《Python实现PDF按页分割的技术指南》PDF文件处理是日常工作中的常见需求,特别是当我们需要将大型PDF文档拆分为多个部分时,下面我们就来看看如何使用Python创建一个灵活的PDF分割工具吧... 目录需求分析技术方案工具选择安装依赖完整代码实现使用说明基本用法示例命令输出示例技术亮点实际应用场景扩

mybatis中resultMap的association及collectio的使用详解

《mybatis中resultMap的association及collectio的使用详解》MyBatis的resultMap定义数据库结果到Java对象的映射规则,包含id、type等属性,子元素需... 目录1.reusltmap的说明2.association的使用3.collection的使用4.总

小白也能轻松上手! 路由器设置优化指南

《小白也能轻松上手!路由器设置优化指南》在日常生活中,我们常常会遇到WiFi网速慢的问题,这主要受到三个方面的影响,首要原因是WiFi产品的配置优化不合理,其次是硬件性能的不足,以及宽带线路本身的质... 在数字化时代,网络已成为生活必需品,追剧、游戏、办公、学习都离不开稳定高速的网络。但很多人面对新路由器

C#解析JSON数据全攻略指南

《C#解析JSON数据全攻略指南》这篇文章主要为大家详细介绍了使用C#解析JSON数据全攻略指南,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、为什么jsON是C#开发必修课?二、四步搞定网络JSON数据1. 获取数据 - HttpClient最佳实践2. 动态解析 - 快速

mybatis-plus QueryWrapper中or,and的使用及说明

《mybatis-plusQueryWrapper中or,and的使用及说明》使用MyBatisPlusQueryWrapper时,因同时添加角色权限固定条件和多字段模糊查询导致数据异常展示,排查发... 目录QueryWrapper中or,and使用列表中还要同时模糊查询多个字段经过排查这就导致只要whe

Olingo分析和实践之EDM 辅助序列化器详解(最佳实践)

《Olingo分析和实践之EDM辅助序列化器详解(最佳实践)》EDM辅助序列化器是ApacheOlingoOData框架中无需完整EDM模型的智能序列化工具,通过运行时类型推断实现灵活数据转换,适用... 目录概念与定义什么是 EDM 辅助序列化器?核心概念设计目标核心特点1. EDM 信息可选2. 智能类

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

Olingo分析和实践之ODataImpl详细分析(重要方法详解)

《Olingo分析和实践之ODataImpl详细分析(重要方法详解)》ODataImpl.java是ApacheOlingoOData框架的核心工厂类,负责创建序列化器、反序列化器和处理器等组件,... 目录概述主要职责类结构与继承关系核心功能分析1. 序列化器管理2. 反序列化器管理3. 处理器管理重要方

SpringBoot集成MyBatis实现SQL拦截器的实战指南

《SpringBoot集成MyBatis实现SQL拦截器的实战指南》这篇文章主要为大家详细介绍了SpringBoot集成MyBatis实现SQL拦截器的相关知识,文中的示例代码讲解详细,有需要的小伙伴... 目录一、为什么需要SQL拦截器?二、MyBATis拦截器基础2.1 核心接口:Interceptor

虚拟机Centos7安装MySQL数据库实践

《虚拟机Centos7安装MySQL数据库实践》用户分享在虚拟机安装MySQL的全过程及常见问题解决方案,包括处理GPG密钥、修改密码策略、配置远程访问权限及防火墙设置,最终通过关闭防火墙和停止Net... 目录安装mysql数据库下载wget命令下载MySQL安装包安装MySQL安装MySQL服务安装完成