Mybatis-plus自动填充不生效或自动填充数据为null原因及解决方案

下面将详细讲解"Mybatis-plus自动填充不生效或自动填充数据为null原因及解决方案"的攻略。

一、问题描述

当我们在使用Mybatis-plus的自动填充功能时,有时候会遇到自动填充不生效或自动填充数据为null的情况,这时候我们需要找到问题所在并进行解决。

二、原因分析

自动填充不生效或自动填充数据为null的原因通常有以下几种情况:

  1. 没有开启自动填充功能。 在Mybatis-plus中,自动填充功能需要在实体类中使用注解进行配置,如果没有进行配置则无法使用自动填充功能。

  2. 自动填充字段的属性值为null。 Mybatis-plus自动填充功能需要实体类的属性值,在sql执行前进行自动填充,如果属性值为null,则无法自动填充。

  3. 自动填充注解使用不正确。 Mybatis-plus提供了多个自动填充注解,注解使用不正确也会导致自动填充不生效或自动填充数据为null。

三、解决方案

针对上述问题所列出的原因,下面我们分别提供解决方案:

  1. 配置自动填充功能

在实体类中开启自动填充功能需要使用Mybatis-plus提供的注解。例如,我们可以在需要自动填充创建时间和更新时间的实体类中添加如下的注解:

@Data
public class User {
    @TableId
    private Long id;

    private String name;

    @TableField(fill = FieldFill.INSERT)
    private LocalDateTime createTime;

    @TableField(fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;
}

其中,@TableField(fill = FieldFill.INSERT)表示在插入数据时自动填充createTime属性,@TableField(fill = FieldFill.INSERT_UPDATE)表示在插入和更新数据时自动填充updateTime属性。

  1. 验证自动填充字段的属性值

如果自动填充字段的属性值为null,则无法自动填充。因此,我们需要在插入或更新数据前,确保自动填充字段的属性值不为null。例如,我们可以在service层的insert方法中添加如下代码:

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
    @Override
    public boolean save(User entity) {
        entity.setCreateTime(LocalDateTime.now());
        entity.setUpdateTime(LocalDateTime.now());
        return super.save(entity);
    }
}
  1. 使用正确的自动填充注解

Mybatis-plus提供了多个自动填充注解,为了避免使用不正确的注解而导致自动填充不生效或自动填充数据为null,我们需要使用正确的注解。以下是常用的自动填充注解:

  • @TableField(fill = FieldFill.INSERT):插入数据时自动填充字段的值

  • @TableField(fill = FieldFill.UPDATE):更新数据时自动填充字段的值

  • @TableField(fill = FieldFill.INSERT_UPDATE):插入和更新数据时自动填充字段的值

四、示例说明

以下是针对自动填充不生效或自动填充数据为null的解决方案的两个示例说明:

示例1

在实体类中没有配置自动填充,导致自动填充不生效。这时候我们需要在实体类中添加相应的注解来开启自动填充功能。例如,如下User实体类中,我们需要添加createTime和updateTime属性的自动填充注解。

@Data
public class User {
    @TableId
    private Long id;

    private String name;

    private LocalDateTime createTime;

    private LocalDateTime updateTime;
}

添加自动填充注解后的实体类代码如下:

@Data
public class User {
    @TableId
    private Long id;

    private String name;

    @TableField(fill = FieldFill.INSERT)
    private LocalDateTime createTime;

    @TableField(fill = FieldFill.INSERT_UPDATE)
    private LocalDateTime updateTime;
}

示例2

在插入数据时,自动填充字段的属性值为null,导致自动填充不生效。这时候我们需要在插入数据前,对自动填充字段的属性值进行设置。例如,如下的UserServiceImpl中,我们在save方法中对自动填充字段的属性值进行设置。

@Service
public class UserServiceImpl extends ServiceImpl<UserMapper, User> implements UserService {
    @Override
    public boolean save(User entity) {
        entity.setCreateTime(LocalDateTime.now());
        entity.setUpdateTime(LocalDateTime.now());
        return super.save(entity);
    }
}

五、总结

以上就是关于"Mybatis-plus自动填充不生效或自动填充数据为null原因及解决方案"的攻略。我们可以通过配置自动填充功能、验证自动填充字段的属性值或使用正确的自动填充注解来解决自动填充不生效或自动填充数据为null的问题。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Mybatis-plus自动填充不生效或自动填充数据为null原因及解决方案 - Python技术站

(0)
上一篇 2023年5月18日
下一篇 2023年5月18日

相关文章

  • Python3 MySQL 数据库连接的使用示例

    首先我们需要安装 Python3 和 MySQL,比如在 Ubuntu 系统下可以使用以下命令进行安装: sudo apt-get update sudo apt-get install python3 sudo apt-get install mysql-server 接着需要安装 Python3 中连接 MySQL 的库,有很多不同的库可供选择,比如 m…

    database 2023年5月21日
    00
  • cmd中MySQL中文数据乱码问题解决方法

    下面是详细讲解“cmd中MySQL中文数据乱码问题解决方法”的完整攻略。 问题背景 在使用cmd命令行窗口操作MySQL数据库时,有时会遇到中文数据乱码问题,这主要是由于cmd默认使用的编码格式为gbk,而MySQL默认使用的编码格式为utf8,两者不兼容所导致的。 解决方法 (以下操作均在cmd命令行窗口中进行) 1. 修改MySQL客户端默认编码格式为g…

    database 2023年5月18日
    00
  • Linux(Unix)中误删除的文件恢复方法

    下面是针对“Linux(Unix)中误删除的文件恢复方法”的完整攻略。 1. 前言 在 Linux(或 Unix)系统上,误删文件是一个非常常见的错误操作,但好在 Linux 工具箱中有一些特殊的工具可以支持我们从磁盘中恢复这些文件。在本攻略中,我将介绍两种主要的误删除文件恢复方法,包括基于命令行的方法和基于应用程序的工具方法。 2. 使用命令行恢复文件 L…

    database 2023年5月22日
    00
  • 如何使用Python在MySQL中使用多列索引?

    在MySQL中,可以使用多列索引来加速多列查询。在Python中,可以使用MySQL连接来执行多列索引查询。以下是在Python中使用多列索引的完整攻略,包括多列索引的基本语法、使用多列索引的示例以及如何在Python中使用多列索引。 多列索引的基本语法 在MySQL中,可以使用CREATE INDEX语句来创建多列索引。以下是创建多列索引的基本语法: CR…

    python 2023年5月12日
    00
  • SQL SERVER中各类触发器的完整语法及参数说明

    SQL SERVER中的触发器可以帮助在特定情况下自动执行一些操作,例如在更新表格时,可以自动更新相关数据。以下是SQL SERVER中各类触发器的详细语法及参数说明: 1. 创建触发器 创建触发器需要使用CREATE TRIGGER语句,语法如下: CREATE TRIGGER trigger_name ON table_name FOR {INSERT,…

    database 2023年5月21日
    00
  • sql获得当前时间以及SQL比较时间大小详解

    SQL获得当前时间 获取当前时间可以使用MySQL内置函数NOW(),如下SQL语句可以获取当前时间: SELECT NOW(); 当然,也可以使用CURRENT_TIMESTAMP来获取当前时间: SELECT CURRENT_TIMESTAMP; SQL比较时间大小 如果需要比较两个时间的大小,可以使用比较运算符如”>”, “<“, “&gt…

    database 2023年5月21日
    00
  • Docker部署Mysql,.Net6,Sqlserver等容器

    下面是Docker部署Mysql,.Net6,Sqlserver等容器的完整攻略: 安装Docker 在Ubuntu和Debian上安装Docker有两种方法:使用Docker官方存储库安装或使用默认存储库安装。本文采用后者,使用默认存储库安装Docker。 运行以下命令安装相关依赖: sudo apt-get update sudo apt-get ins…

    database 2023年5月22日
    00
  • oracle 11g 设置用户密码大小写敏感测试

    Oracle 11g 设置用户密码大小写敏感测试攻略 一、背景 Oracle数据库是一款功能强大的关系型数据库,其安全性得到了广泛的认可。在Oracle数据库中,设置用户密码大小写敏感需要开启Case Sensitive参数。本文将为您介绍如何开启Case Sensitive参数,并进行简单的测试。 二、设置用户密码大小写敏感 1. 连接Oracle数据库 …

    database 2023年5月22日
    00
合作推广
合作推广
分享本页
返回顶部