温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MyBatisPlus如何使用@TableField注解处理默认填充时间的问题

发布时间:2022-01-15 11:23:52 来源:亿速云 阅读:414 作者:小新 栏目:开发技术

这篇文章给大家分享的是有关MyBatisPlus如何使用@TableField注解处理默认填充时间的问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

使用@TableField注解处理默认填充时间的情况

在数据库的表中创建时间,修改时间!这些个操作一般都是自动化完成的,我们不希望手动更新。

阿里巴巴开发手册:所有的数据库表:gmt_create,gmt_modified几乎所有的表都要配置上!而且需要自动化!

1.利用数据库填写默认时间

在表中新增字段create_time,update_time,给这个字段设置一个current_timestamp时间戳,这样默认值就是当前时间,但是mysql版本如果过低的话是不支持current_timestamp关键字的

如下图:

MyBatisPlus如何使用@TableField注解处理默认填充时间的问题

2.使用自动填充默认填充插入或更新数据库时

表中牵涉到的时间 编写处理器类

首先需要编写一个处理器,如下图:

MyBatisPlus如何使用@TableField注解处理默认填充时间的问题

注意上面的处理器一定要加上@Component注解表示把此处理器注入到IOC容器中。SpringBoot中无论是处理器包handler还是配置包config都需要把里面的类加上@Component注解表示把类注入到IOC容器中,要不然处理器和配置类不会生效。

给实体类的属性添加@TableField注解

其次要在对应的实体类上的属性上加上@TableField注解

如下图:

MyBatisPlus如何使用@TableField注解处理默认填充时间的问题

测试

最后写一个单元测试,测试更新或者插入的时候能否实现createTime和updateTime的自动填充操作

如下图:

MyBatisPlus如何使用@TableField注解处理默认填充时间的问题

测试成功的结果状态

数据库中的字段类型要设置成是datetime,添加成功后的数据格式

如下图:

MyBatisPlus如何使用@TableField注解处理默认填充时间的问题

类型设置

数据库中的表中的时间字段create_time和update_time设置成datetime类型,User实体中的createTime和updateTime和处理器中的new Date()所有的时间类型用java.util.Date包中的Date类型。

感谢各位的阅读!关于“MyBatisPlus如何使用@TableField注解处理默认填充时间的问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI