前言
数据库表设计的时候,一般都会设计一些所以表都需要的常见字段,例如:创建时间、修改时间、逻辑删除等字段。如果生成数据的时候需要每个实体都去set相关值,就太繁琐了。而Mybatis-plus正好提供了这种自动填充数据的功能。
今天这篇文章就来讲一讲如何配置自动填充的相关功能!
一、配置自动填充和逻辑删除
1. 实体类增加注解
查看自动生成的代码,打开Member.java,配置自动填充和逻辑删除。
需要自动填充的字段加上注解:
@TableField(fill = FieldFill.INSERT)或者是@TableField(fill = FieldFill.UPDATE)
逻辑删除有两种配置:
-
一种是在实体类的字段上加上注解@TableLogic
-
一种是在配置文件里配置全局的字段,且还会追加Where条件(本例采用这种方式配置)
2. 创建元对象处理器接口
这里有个地方需要注意:数据库中的tinnyint类型的字段,MP默认在实体中生成Boolean类型的属性。所以deleted初始值要写 false。
@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert fill ....");
this.setFieldValByName("createTime", new Date(), metaObject);
this.setFieldValByName("deleted", false, metaObject);
}
@Override
public void updateFill(MetaObject metaObject) {
log.info("start update fill ....");
this.setFieldValByName("updateTime", new Date(), metaObject);
}
}
3. 测试
controller层编写保存、更新、删除等方法
@PostMapping(value = "del/{memberId}")
public boolean deleteById(@PathVariable Long memberId){
return memberService.removeById(memberId);
}
@PostMapping(value = "save")
public boolean save(@RequestBody Member member){
if (null == member.getMemberId()) {
return memberService.save(member);
}
return memberService.updateById(member);
}
使用postman工具进行测试
删除接口测试,成功,查看控制台输出的sql是update语句
测试保存接口,未传主键id就是新增,传了就是修改,查看sql可看到自动填充的字段
二、配置热部署
spring-boot-devtools是一个为开发者服务的一个模块,其中最重要的功能就是当代码发生改变的时候
监听classpath下的文件变动,并且会立即重启应用程序,但是速度比手动停止后再启动更快。
1. 引入依赖
<!--开发者工具-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
<!-- optional=true,依赖不会传递,该项目依赖devtools;之后依赖该项目的项目如果想要使用devtools,需要重新引入 -->
</dependency>
2. 编译文件/项目
idea工具每次编辑完会自动保存,但不会自动编译,而devtools的原理是监听编译后的文件改动,所以我们还需要手工编译项目或刚刚修改的文件,或者直接设置IDEA的自动编译。
手工编辑项目如下所示:
ldea设置自动编译如下所示:
先Setting设置
再按键 ctrl + shift + alt + /,弹出Registry选择