使用Mybatis-plus實(shí)現(xiàn)時(shí)間自動(dòng)填充(代碼直接可用)
一. 搭建基礎(chǔ)項(xiàng)目
引入依賴
<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!--lombok 依賴--> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <optional>true</optional> </dependency> <!-- swagger2 依賴 --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.7.0</version> </dependency> <!-- Swagger第三方ui依賴 --> <dependency> <groupId>com.github.xiaoymin</groupId> <artifactId>swagger-bootstrap-ui</artifactId> <version>1.9.6</version> </dependency> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>3.3.1.tmp</version> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.26</version> </dependency> </dependencies>
controller
@RestController public class TestController { @Autowired private IProjectService projectService; @ApiOperation("新增項(xiàng)目") @PostMapping("/") public void addProjectWrite(@RequestBody Project project) { projectService.save(project); } }
service
public interface IProjectService extends IService<Project> { }
serviceImpl
@Service public class ProjectServiceImpl extends ServiceImpl<ProjectMapper, Project> implements IProjectService { }
Mapper
@Service public class ProjectServiceImpl extends ServiceImpl<ProjectMapper, Project> implements IProjectService { }
Pojo
@Data @EqualsAndHashCode(callSuper = false) @Accessors(chain = true) @TableName("ts_project") @ApiModel(value="Project對象", description="撰寫項(xiàng)目申請書的基本內(nèi)容") public class Project implements Serializable { private static final long serialVersionUID = 1L; @TableId(value = "id", type = IdType.AUTO) private String id; private Integer workNumber; private Integer adminId; private String name; @ApiModelProperty(value = "創(chuàng)建時(shí)間") @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "Asia/Shanghai") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date gmtCreate; @ApiModelProperty(value = "更新時(shí)間") @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "Asia/Shanghai") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date gmtModified; }
application.yml
server: # 端口 port: 8081 spring: # 數(shù)據(jù)源配置 datasource: driver-class-name: com.mysql.cj.jdbc.Driver url: jdbc:mysql://localhost:3306/test2?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai username: root password: root # Mybatis-plus配置 mybatis-plus: #配置Mapper映射文件 mapper-locations: classpath*:/mapper/*Mapper.xml # 配置MyBatis數(shù)據(jù)返回類型別名(默認(rèn)別名是類名) type-aliases-package: com.xxxx.server.pojo configuration: # 自動(dòng)駝峰命名 map-underscore-to-camel-case: fals
啟動(dòng)類
@SpringBootApplication @EnableScheduling @MapperScan("com.xxxx.server.mapper") public class TestApplication { public static void main(String[] args) { SpringApplication.run(TestApplication.class,args); } }
搭建完成
此時(shí)執(zhí)行操作,并不會(huì)在表中添加時(shí)間,如下:
二. 設(shè)置自動(dòng)填充
創(chuàng)建MyMetaObjectHandler文件,實(shí)現(xiàn)自動(dòng)填充
/** * 自動(dòng)填充時(shí)間 */ @Component public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObject) { this.setFieldValByName("gmtCreate", new Date(), metaObject); this.setFieldValByName("gmtModified", new Date(), metaObject); } @Override public void updateFill(MetaObject metaObject) { this.setFieldValByName("gmtModified", new Date(), metaObject); } }
修改pojo類
@Data @EqualsAndHashCode(callSuper = false) @Accessors(chain = true) @TableName("ts_project") @ApiModel(value="Project對象", description="撰寫項(xiàng)目申請書的基本內(nèi)容") public class Project implements Serializable { private static final long serialVersionUID = 1L; @TableId(value = "id", type = IdType.AUTO) private String id; private Integer workNumber; private Integer adminId; private String name; @ApiModelProperty(value = "創(chuàng)建時(shí)間") @TableField(fill = FieldFill.INSERT) @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "Asia/Shanghai") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date gmtCreate; @ApiModelProperty(value = "更新時(shí)間") @TableField(fill = FieldFill.INSERT_UPDATE) @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss",timezone = "Asia/Shanghai") @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss") private Date gmtModified; }
- 在gmtCreate上增加 @TableField(fill = FieldFill.INSERT) 表示創(chuàng)建時(shí)間。
- 在gmtModified上增加 @TableField(fill = FieldFill.INSERT_UPDATE)表示修改時(shí)間。
- gmtCreate和gmtModified需要與自定義方法中的字段相匹配。
此時(shí)執(zhí)行操作,會(huì)在表中添加時(shí)間,如下:
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- MyBatis-Plus自動(dòng)填充字段的詳細(xì)教程
- Mybatis-Plus實(shí)現(xiàn)公共字段自動(dòng)填充的項(xiàng)目實(shí)踐
- MyBatis-Plus中自動(dòng)填充功能的用法示例詳解
- mybatis-plus 新增/修改如何實(shí)現(xiàn)自動(dòng)填充指定字段
- 實(shí)例詳解MyBatis-plus自動(dòng)填充功能
- Mybatis-Plus自動(dòng)填充更新操作相關(guān)字段的實(shí)現(xiàn)
- mybatis-plus自動(dòng)填充插入更新時(shí)間有8小時(shí)時(shí)差
- MyBatis-Plus 自動(dòng)填充的實(shí)現(xiàn)示例
相關(guān)文章
springboot?項(xiàng)目啟動(dòng)后無日志輸出直接結(jié)束的解決
這篇文章主要介紹了springboot?項(xiàng)目啟動(dòng)后無日志輸出直接結(jié)束的解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-12-12SpringBoot+ECharts是如何實(shí)現(xiàn)數(shù)據(jù)可視化的
今天帶大家學(xué)習(xí)的是關(guān)于Java的相關(guān)知識,文章圍繞著SpringBoot+ECharts怎么實(shí)現(xiàn)數(shù)據(jù)可視化展開,文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06Spring中@ConditionalOnProperty注解的作用詳解
這篇文章主要介紹了Spring中@ConditionalOnProperty注解的作用詳解,@ConditionalOnProperty注解主要是用來判斷配置文件中的內(nèi)容來決定配置類是否生效用的,如果條件不匹配,則配置類不生效,需要的朋友可以參考下2024-01-01詳解如何通過Java實(shí)現(xiàn)類似Nginx代理
最近遇到一個(gè)問題,在內(nèi)網(wǎng)環(huán)境中部署的項(xiàng)目需要調(diào)用外網(wǎng)完成一些應(yīng)用,一般情況我們可以通過增加一臺(tái)機(jī)器,部署到可以訪問外網(wǎng)的服務(wù)器上,然后內(nèi)網(wǎng)直接連接該機(jī)器通過Nginx進(jìn)行代理即可,所以本文介紹了如何通過Java實(shí)現(xiàn)類似Nginx代理,需要的朋友可以參考下2024-08-08