MyBatis-Plus不使用数据库默认值的问题及解决

 更新时间:2022年07月07日 09:36:39   作者:养-乐多  
这篇文章主要介绍了MyBatis-Plus不使用数据库默认值的问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

MyBatis-Plus不使用数据库默认值的问题

有时候我们在设计数据表时希望某些字段使用默认值,比如create_time、和update_time这样在数据库中设置:

`create_time` datetime DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`update_time` datetime ON UPDATE CURRENT_TIMESTAMP COMMENT '更新时间'

Navicat截图如下(网络图片)

也就是说只要是插入操作create_time和update_time字段就使用系统时间,只要是更新时update_time字段也随着更新,无需手动赋值mysql自动帮我们做了。

MyBatis-Plus如何设置呢?

有时候我们的业务是先查询到实体对象,然后修改某个值再进行更新,比如这样:

        LambdaQueryWrapper<ImKnowledgeSearchRecord> lambdaQueryWrapper = new LambdaQueryWrapper<>();
        lambdaQueryWrapper.eq(ImKnowledgeSearchRecord::getKeyword, keyword);
        ImKnowledgeSearchRecord knowledgeSearchRecord = this.getOne(lambdaQueryWrapper, true);
        if (knowledgeSearchRecord == null) {
            knowledgeSearchRecord = new ImKnowledgeSearchRecord();
            knowledgeSearchRecord.setKeyword(keyword);
            knowledgeSearchRecord.setSearchCount(0);
        }        knowledgeSearchRecord.setSearchCount(knowledgeSearchRecord.getSearchCount() + 1);
        // knowledgeSearchRecord.setUpdateTime(null);
this.updateById(knowledgeSearchRecord);

注意上面的实体类中有CreateTime和UpdateTime字段,如果不做任何配置的画,MyBatis-Plus默认使用

this.getOne(lambdaQueryWrapper, true);

查询出来的值作为参数赋值,然后你就会发现update_time字段并没有随着修改而变化,但这不符合我们数据表的设计初衷,那该怎么做?

    /**
     * 创建时间(数据库自动生成,无需手动赋值)
     */
    @TableField(insertStrategy = FieldStrategy.NEVER)
    private Date createTime;
    /**
     * 修改时间(数据库自动生成,无需手动赋值)
     */
    @TableField(updateStrategy = FieldStrategy.NEVER)
    private Date updateTime;

使用@TableField注解,分别设置插入策略和更新策略为FieldStrategy.NEVER,表示这两个字段不加入SQL,这样生成的插入和修改的SQL语句就不会包含这两个字段。

只使用MyBatis-Plus的注解,而不用配置数据库

我们在项目开发时,特别是多module项目场景时,可能会遇到某些实体类要使用mybatis-plus的注解,如@tableName或者@TableField等, 但是如果引入mybatis依赖就要配置数据库,但实际上有可能这个项目只是个公共实体类、接口类等的一个公共module,在该公共module中写一遍这些实体类,接口等,然后在其他module中直接依赖这个公共module就可以了,所以在这个场景下,这个公共module就不需要连接数据库,自然而然也不需要配置数据库

解决

因为mybatis-plus的maven依赖一旦添加了是需要配置数据库的,所以我们需要换一个依赖

如下所示,mybatis-plus-annotation依赖只包含mybatis-plus的注解

        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-annotation</artifactId>
            <version>3.2.0</version>
        </dependency>

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java设计模式之中介者模式

    Java设计模式之中介者模式

    这篇文章介绍了Java设计模式之中介者模式,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-10-10
  • RestTemplate使用Proxy代理作为跳板发送请求

    RestTemplate使用Proxy代理作为跳板发送请求

    这篇文章主要为大家介绍了RestTemplate使用代理proxy作为跳板发送请求的方法示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-03-03
  • Java启动参数(-, -X, -XX参数)的使用

    Java启动参数(-, -X, -XX参数)的使用

    本文主要介绍了Java启动参数(-, -X, -XX参数)的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • SpringBoot 中使用 Validation 校验参数的方法详解

    SpringBoot 中使用 Validation 校验参数的方法详解

    Validation 是用于检查程序代码中参数的有效性的框架,作为 Spring 框架中的一个参数校验工具,集成在 spring-context 包中,这篇文章主要介绍了SpringBoot 中使用 Validation 校验参数,需要的朋友可以参考下
    2022-05-05
  • Java代理模式与动态代理之间的关系以及概念

    Java代理模式与动态代理之间的关系以及概念

    代理模式是开发中常见的一种设计模式,使用代理模式可以很好的对程序进行横向扩展。动态代理:代理类在程序运行时被创建的代理方式。关键在于动态,程序具有了动态特性,可以在运行期间根据不同的目标对象生成动态代理对象
    2023-02-02
  • Intellij IDEA菜单栏不见了(Main Menu as Separate Toolbar)恢复菜单栏显示的解决办法

    Intellij IDEA菜单栏不见了(Main Menu as Separat

    有人问博主,关于Intellij IDEA菜单栏找不到了,被不小心的操作给隐藏了,怎么办?下面给大家分享解决方案,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • java之TreeUtils生成一切对象树形结构案例

    java之TreeUtils生成一切对象树形结构案例

    这篇文章主要介绍了java之TreeUtils生成一切对象树形结构案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • SpringBoot数据校验功能的实现

    SpringBoot数据校验功能的实现

    这篇文章主要介绍了SpringBoot数据校验功能的实现,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • 双Token无感刷新机制实现方式

    双Token无感刷新机制实现方式

    本文介绍了如何在Vue.js前端和Java后端实现双Token的无感刷新机制,后端通过Jwt过滤器解析Token,前端在请求时携带Token并保存,当Token过期时,前端会自动刷新并重新发送请求,实现无感刷新
    2025-03-03
  • java实现日历(某年的日历,某月的日历)用户完全自定义

    java实现日历(某年的日历,某月的日历)用户完全自定义

    本篇文章介绍了,java实现日历(某年的日历,某月的日历)用户完全自定义。需要的朋友参考下
    2013-05-05

最新评论