当前位置:首页 > 编程教程 > java技术文章 > Mybatis-Plus自动填充的实现示例

Mybatis-Plus自动填充示例代码

  • 发布时间:
  • 作者:码农之家
  • 点击:124

这篇文章主要知识点是关于Mybatis、Plus、自动填充、的内容,如果大家想对相关知识点有系统深入的学习,可以参阅以下电子书

Java语言程序设计与数据结构:基础篇
  • 类型:Java大小:259 MB格式:PDF作者:梁勇
立即下载

Mybatis-Plus自动填充的实现示例

在常用业务中有些属性需要配置一些默认值,MyBatis-Plus提供了实现此功能的插件。在这里修改user表添加 create_time 字段和 update_time 字段,在User类中添加对应属性。

1、为需要自动填充的属性添加注解 @TableField

提供了4种自动填充策略:DEFAULT,默认不处理。INSERT,插入填充字段。UPDATE,更新填充字段。INSERT_UPDATE,插入和更新填充字段。

@Data
public class User {
  private Long id;
  private String name;
  private Integer age;
  private String email;

  @TableField(fill = FieldFill.INSERT)
  private Date createTime;
  @TableField(fill = FieldFill.INSERT_UPDATE)
  private Date updateTime;
}

2、实现字段填充控制器,编写自定义填充规则

实现 MetaObjectHandler 接口,实现 insertFill 和 updateFill 方法,此处的 create_time 和update_time字段需要插入时填充值, 只有 update_time 字段在修改时需要填充,所以策略如下。

//需要将自定义填充控制器注册为组件

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {

  private static final Logger LOGGER= LoggerFactory.getLogger(MyMetaObjectHandler.class);

  //insert操作时要填充的字段
  @Override
  public void insertFill(MetaObject metaObject) {
    LOGGER.info("start insert fill ...");
    //根据属性名字设置要填充的值
    this.setFieldValByName("createTime",new Date(),metaObject);
    this.setFieldValByName("updateTime",new Date(),metaObject);
  }

  //update操作时要填充的字段
  @Override
  public void updateFill(MetaObject metaObject) {
    LOGGER.info("start insert fill ...");
    this.setFieldValByName("updateTime",new Date(),metaObject);
  }
}

3、插入数据测试

@RunWith(SpringRunner.class)
@SpringBootTest
public class CRUDTest {
  @Autowired
  private UserMapper userMapper;

  @Test
  public void testInsert(){
    User user = new User();
    user.setName("jack11");
    user.setAge(20);
    user.setEmail("4849111@qq.com");

    int result= userMapper.insert(user);
    System.out.println(result);
    System.out.println(user);
  } 
}

4、修改数据测试

@Test
public void testUpdate(){
  User user = new User();
  user.setId(2L);
  user.setName("Jackie");
  int result = userMapper.updateById(user);
  System.out.println(result);
}

一次插入数据后,create_time和update_time都被填充了设置的时间,做update操作后只有update_time的进行了填充修改。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持码农之家。

以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。

Java 相关电子书
学习笔记
网友NO.915335

Mybatis-Plus 搭建与使用入门(小结)

Mybatis-Plus(简称MP)是一个 Mybatis 的增强工具,在 Mybatis 的基础上只做增强不做改变,为简化开发、提高效率而生。 中文文档 :http://baomidou.oschina.io/mybatis-plus-doc/#/ 本文介绍包括 1)如何搭建 2)代码生成(controller、service、mapper、xml) 3)单表的CRUD、条件查询、分页 基类已经为你做好了 一、如何搭建 1. 首先我们创建一个 springboot 工程 -- https://start.spring.io/ 2. maven 依赖 dependency groupIdcom.baomidou/groupId artifactIdmybatis-plus-boot-starter/artifactId version2.3/version /dependency !-- velocity 依赖,用于代码生成 -- dependency groupIdorg.apache.velocity/groupId artifactIdvelocity-engine-core/artifactId version2.0/version /dependency 3. 配置(因为感觉太啰嗦,这里省略了数据源的配置) application.properties mybatis-plus.mapper-locations=classpath:/mapper/*Mapper.xmlmybatis-plus.typeAliasesPackage=com.taven.web.springbootmp.entitymybatis-plu……

网友NO.183333

Mybatis-Plus 多表联查分页的实现代码

上一节,简单讲述了 Mybatis-Plus 搭建与使用入门,这一节,简单讲一下如何使用 MP 实现多表分页。 分析 使用的工程,依旧是 spring-boot,关于分页,官网给出了一个单表的demo,其实多表分页实现原理相同,都是通过 mybatis 的拦截器 (拦截器做了什么?他会在你的 sql 执行之前,为你做一些事情,例如分页,我们使用了 MP 不用关心 limit,拦截器为我们拼接。我们也不用关心总条数,拦截器获取到我们 sql 后,拼接 select count(*) 为我们查询总条数,添加到参数对象中)。 实现 1. 配置拦截器 @EnableTransactionManagement@Configuration@MapperScan("com.web.member.mapper")public class MybatisPlusConfig { /** * mybatis-plus SQL执行效率插件【生产环境可以关闭】 */ @Bean public PerformanceInterceptor performanceInterceptor() { return new PerformanceInterceptor(); } /* * 分页插件,自动识别数据库类型 多租户,请参考……

网友NO.603633

SpringBoot整合MybatisPlus的简单教程实现(简单整合)

最近在研究springboot,顺便就会看看数据库连接这一块的知识 ,所以当我发现有通用Mapper和MybatisPlus这两款网络上比较火的简化mybatis开发的优秀软件之后。就都想试一下,看看哪一款比较适合自己。 先创建一个springboot的项目,可以参考我之前的文章Spring Boot 的简单教程(一) Spring Boot 项目的创建。 创建好springboot之后就需要整合mybatis和mybatis-plus了。 打开pom.xml文件,将最新的mybatis相关的包都引用进来。 !-- 这是mysql的依赖 -- dependency groupIdmysql/groupId artifactIdmysql-connector-java/artifactId scoperuntime/scope /dependency !-- 这是lombok的依赖 -- dependency groupIdorg.projectlombok/groupId artifactIdlombok/artifactId optionaltrue/optional /dependency !-- 这是mybatis-plus依赖 -- dependency groupIdcom.baomidou/groupId artifactIdmybatis-plus-boot-starter/artifactId version3.1.1/version /dependency !-- 这是mybatis-plus的代码自动生成器……

<
1
>

Copyright 2018-2020 www.xz577.com 码农之家

版权投诉 / 书籍推广 / 赞助:520161757@qq.com