好得很程序员自学网

<tfoot draggable='sEl'></tfoot>

MyBatis-Plus自动填充功能失效导致的原因及解决

1:先检查 字段有没有加上注解 @tablefield(fill = fieldfill.insert_update)

?

1

2

@tablefield (fill = fieldfill.insert_update)

  private date updatedtime;

2:有没有实现 metaobjecthandler 接口 ,并且加入到 spring 容器中

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

@component

public class mymetaobjecthandler implements metaobjecthandler {

 

  @override

  public void insertfill(metaobject metaobject) {

this .strictinsertfill(metaobject, "createdtime" , date. class , new date());

this .strictinsertfill(metaobject, "updatedtime" , date. class , new date());

  }

 

  @override

  public void updatefill(metaobject metaobject) {

this .strictupdatefill(metaobject, "updatedtime" , date. class , new date());

  }

}

3: @component 是否扫码注入进去

4: basemapper.update(null,wrappers.<users>lambdaupdate()) 这样的写法是没有拦截到的,所以无效

xml 写的也无效

@update 注解也无效

?

1

2

3

basemapper.update( null , wrappers.<users>lambdaupdate()

.set(users::getconcerntype, 2 )

.eq(users::getid,userid));

应该改为

?

1

2

basemapper.update(users, wrappers.<users>lambdaupdate()

.set(users::getconcerntype, 2 ));

或者

?

1

2

3

4

users users = new users();

users.setid(userid);

users.setconcerntype( 1 );

basemapper.updatebyid(users);

这样可以拿到表相关信息,会执行我们的 metaobjecthandler 实现接口

补充:springboot+mybatisplus 公共字段自动填充 mybatisplusconfig配置不生效解决

springboot+mybatisplus mybatisplusconfig配置不生效问题

先说下工程目录

典型的maven工程,在common中配置mybatisplus配置信息,在base中进行crud操作。

遇到的问题:

在mybatisplus中配置了公共字段(create_time,upate_time),想在插入数据时,自动插入这两条字段。

配置如下:

abstractentity 代码:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

/**

  * 实体父类

  */

@data

public abstract class abstractentity extends model implements serializable {

  private static final long serialversionuid = 1l;

  /**

   * id

   */

  @tableid

  private string id;

  /**

   * 创建时间

   */

  @datetimeformat (pattern = "yyyy-mm-dd hh:mm:ss" )

  @jsonformat (timezone = "gmt+8" , pattern = "yyyy-mm-dd hh:mm:ss" )

  @tablefield (value = "create_time" , fill = fieldfill.insert)

  public date createtime;

  /**

   * 修改时间

   */

  @datetimeformat (pattern = "yyyy-mm-dd hh:mm:ss" )

  @jsonformat (timezone = "gmt+8" , pattern = "yyyy-mm-dd hh:mm:ss" )

  @tablefield (value = "update_time" , fill = fieldfill.update)

  public date updatetime;

}

metahandler代码:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

@slf4j

@component

public class metahandler implements metaobjecthandler {

  /**

   * 新增数据执行

   * @param metaobject

   */

  @override

  public void insertfill(metaobject metaobject) {

   this .setfieldvalbyname( "createtime" , new date(), metaobject);

   this .setfieldvalbyname( "updatetime" , new date(), metaobject);

  }

  /**

   * 更新数据执行

   * @param metaobject

   */

  @override

  public void updatefill(metaobject metaobject) {

   this .setfieldvalbyname( "updatetime" , new date(), metaobject);

  }

}

mybatisplusconfig 代码:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

@configuration

@mapperscan ( "com.lyf.account.**.mapper" )

public class mybatisplusconfig {

  /*

   * 分页插件,自动识别数据库类型

   * 多租户,请参考官网【插件扩展】

   */

  @bean

  public paginationinterceptor paginationinterceptor() {

   return new paginationinterceptor();

  }

  @bean

  public globalconfig globalconfig() {

   globalconfig globalconfig = new globalconfig();

   globalconfig.setmetaobjecthandler( new metahandler());

   return globalconfig;

  }

}

配置后,启动baseapplication,使用postman 进行测试,发现数据成功插入,但是创建时间并没有插入

在mybatisplusconfig 的 globalconfig.setmetaobjecthandler(new metahandler());处打断点进行调试,发现代码并没有执行到这个类 (╯▔皿▔)╯ 检查 baseapplication 才发现,没有在启动类中扫描该配置文件@。@

以下是修改过的baseapplication类:

?

1

2

3

4

5

6

7

8

9

10

11

@springbootapplication

@componentscan ({ "com.lyf.account.mybatis.config" , "com.lyf.account.base" })

public class baseapplication {

  public static void main(string[] args) {

   springapplication.run(baseapplication. class , args);

  }

  @bean

  public idworker idworker (){

   return new idworker( 1 , 1 );

  }

}

加入扫描装配后,再次进行测试,插入数据完美将创建时间加入o(∩_∩)o

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。

原文链接:https://blog.csdn.net/publicv/article/details/108582719

查看更多关于MyBatis-Plus自动填充功能失效导致的原因及解决的详细内容...

  阅读:50次