Mybatis-plus如何配置自动填充和逻辑删除的功能
前言
数据库表设计的时候,一般都会设计一些所以表都需要的常见字段,例如:创建时间、修改时间、逻辑删除等字段。如果生成数据的时候需要每个实体都去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选择
总结
感谢大家的阅读,以上就是今天要讲的内容,本文简单介绍了如何配置自动填充字段,逻辑删除,以及配置热部署功能。若有不足之处,还请多多批评指正。
作者:Java升级之路
链接:https://juejin.cn/post/7023180624110305310