内容简介:通常来说,我们都有这样的需求:我需要知道库中的数据是由谁创建,什么时候创建,最后一次修改时间是什么时候,最后一次修改人是谁。guns-lite最新代码已经实现该需求,具体实现方式网上有很多资料,这里做会搬运...
通常来说,我们都有这样的需求:我需要知道库中的数据是由谁创建,什么时候创建,最后一次修改时间是什么时候,最后一次修改人是谁。guns-lite最新代码已经实现该需求,具体实现方式网上有很多资料,这里做会搬运工,将guns-lite的实现步骤罗列如下:
在Spring jpa中可以通过在实体bean的属性或者方法上添加以下注解来实现上述需求@CreatedDate、@CreatedBy、@LastModifiedDate、@LastModifiedBy。
@CreatedDate 表示该字段为创建时间时间字段,在这个实体被insert的时候,会设置值
@CreatedBy 表示该字段为创建人,在这个实体被insert的时候,会设置值
@LastModifiedDate 最后修改时间 实体被update的时候会设置
@LastModifiedBy 最后修改人 实体被update的时候会设置
使用方式
实体类添加注解
首先在实体中对应的字段加上上述4个注解
在guns-lite中我们提取了一个基础实体类BaseEntity,并将对应的字段添加上述4个注解,所有需要记录维护信息的表对应的实体都集成该类
import org.springframework.data.annotation.CreatedBy; import org.springframework.data.annotation.CreatedDate; import org.springframework.data.annotation.LastModifiedBy; import org.springframework.data.annotation.LastModifiedDate; import javax.persistence.Column; import javax.persistence.GeneratedValue; import javax.persistence.Id; import javax.persistence.MappedSuperclass; import java.io.Serializable; import java.util.Date; @MappedSuperclass @Data public abstract class BaseEntity implements Serializable { @Id @GeneratedValue private Long id; @CreatedDate @Column(name = "create_time",columnDefinition="DATETIME COMMENT '创建时间/注册时间'") private Date createTime; @Column(name = "create_by",columnDefinition="bigint COMMENT '创建人'") @CreatedBy private Long createBy; @LastModifiedDate @Column(name = "modify_time",columnDefinition="DATETIME COMMENT '最后更新时间'") private Date modifyTime; @LastModifiedBy @Column(name = "modify_by",columnDefinition="bigint COMMENT '最后更新人'") private Long modifyBy; }
实现AuditorAware接口返回操作人员的id
配置完上述4个注解后,在jpa.save方法被调用的时候,时间字段会自动设置并插入数据库,但是CreatedBy和LastModifiedBy并没有赋值 这两个信息需要实现AuditorAware接口来返回操作人员的id
首先需要在项目启动类添加@EnableJpaAuditing 注解来启用审计功能
@SpringBootApplication @EnableJpaAuditing public class AdminApplication extends WebMvcConfigurerAdapter { //省略 }
然后实现AuditorAware接口返回操作人员的id
@Configuration public class UserIDAuditorConfig implements AuditorAware<Long> { @Override public Long getCurrentAuditor() { ShiroUser shiroUser = ShiroKit.getUser(); if(shiroUser!=null){ return shiroUser.getId(); } return null; } }
以上所述就是小编给大家介绍的《guns-lite 将所有表增加维护人员和维护时间信息》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 如何编写无法维护的代码
- Debian 包维护者辞职
- 从 VantCompoent 谈 小程序维护
- 从 VantComponent 谈 小程序维护
- 开源维护者,必有一战!
- 3 分布式 Git - 维护项目
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
数据结构与算法(Java语言版)
(美) Adam Drozdek著;周翔 / 机械工业出版社 / 2003-07-01 / 49.50元
数据结构与算法:Java语言版,ISBN:9787111119029,作者:(美)Adam Drozdek著;周翔[等]译;周翔译一起来看看 《数据结构与算法(Java语言版)》 这本书的介绍吧!