8人参与 • 2025-07-24 • Java
mybatis-plus(简称 mp)是 mybatis 的增强工具包,提供了很多便利的功能,其中 自动赋值实体字段 是开发中非常常见的需求。本文将深入探讨 mybatis-plus 的自动赋值机制,并通过详细的 java 代码和表格进行对比和解释,帮助大家更好地掌握这个功能。
mybatis-plus 提供了一种便捷的方式来自动填充实体对象中的字段,尤其是在处理一些常见的数据库操作时(如创建时间、更新时间等)。在进行数据插入、更新操作时,常常需要对某些字段进行自动填充,减少手动赋值的工作量,提升开发效率。
createtime
, updatetime
等字段通常需要在插入或更新时自动填充为当前时间。createby
, updateby
等字段通常需要在操作时自动填充当前操作用户。isdeleted
字段,插入时自动填充 0
,更新时填充 1
表示删除。mybatis-plus 的自动赋值字段主要通过 @tablefield
注解与填充策略来实现。它通过配置特定的填充规则,使得在执行插入、更新操作时,某些字段能够自动填充。
mybatis-plus 提供了四种常见的填充策略:
fieldfill.insert
:在插入时填充fieldfill.update
:在更新时填充fieldfill.insert_update
:在插入和更新时都填充fieldfill.default
:不指定填充策略,使用默认填充规则mybatis-plus 提供了两个关键注解用于自动赋值字段的配置:@tablefield
和 @tableid
。
@tablefield
注解用于标识实体类中的字段,配合 fill
属性来定义自动填充的行为。通过 fill
属性,我们可以为字段指定填充策略。
@tablefield(fill = fieldfill.insert) private date createtime; @tablefield(fill = fieldfill.insert_update) private date updatetime;
createtime
字段在插入时自动填充。updatetime
字段在插入和更新时自动填充。@tableid
注解用于指定实体类中的主键字段。在某些情况下,我们也可能需要对主键字段进行自动赋值。通常来说,mybatis-plus 会自动处理主键生成策略(如自增、uuid 等)。
@tableid(type = idtype.auto) private long id;
该配置表示主键 id
使用数据库自增。
为了实现自动赋值,我们需要配置填充策略。填充策略可以在 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 提供的接口,用于处理自动填充的逻辑。通过实现该接口,我们可以在插入和更新时自定义字段的自动填充行为。
假设我们有一个 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; }
在 mapper 接口中,我们可以直接使用 mybatis-plus 提供的 updatebyid
, insert
等方法。
@mapper public interface usermapper extends basemapper<user> { // 自定义的数据库操作方法 }
@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); } }
在上述示例中,createtime
和 updatetime
会在插入和更新时自动填充。
字段类型 | fieldfill.insert | fieldfill.update | fieldfill.insert_update | fieldfill.default |
---|---|---|---|---|
createtime | 仅在插入时填充 | 不会填充 | 会在插入和更新时填充 | 根据默认策略,通常是 insert |
updatetime | 不会填充 | 仅在更新时填充 | 会在插入和更新时填充 | 根据默认策略,通常是 insert |
通过表格,我们可以看到不同填充策略的行为区别。开发者可以根据业务需求来选择合适的填充策略。
metaobjecthandler
,并且 @tablefield(fill = fieldfill.xxx)
注解已加在正确的字段上。@tableid
注解时,需要明确指定主键生成策略(如 idtype.auto
)。metaobjecthandler
配置全局的字段填充策略。通过本文的学习,相信你对 mybatis-plus 自动赋值实体字段的使用有了更深入的理解。合理利用 mybatis-plus 提供的自动填充功能,可以大大提高开发效率并降低出错的概率。希望你在实际开发中能够得心应手地运用这些技巧!
到此这篇关于mybatis-plus 自动赋值实体字段的文章就介绍到这了,更多相关mybatisplus自动赋值内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!
您想发表意见!!点此发布评论
版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。
发表评论