spring-data-jpa配置策略-自动生成创建修改时间与用户信息

博客介绍了项目的相关配置,包括pom依赖、application.yml配置文件,还涉及用户信息配置、基类和实体类配置等,提到实体类使用@DATA注解需引用lombok插件,最后有启动类配置和repository相关内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

pom依赖
  <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.47</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>
application.yml配置文件
spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: jdbc:mysql://localhost:3306/dev
    username: dev
    password: dev
    hikari:
      maximum-pool-size: 15
      minimum-idle: 5
      connection-timeout: 30000 # default 30s, ms
      pool-name: SimpleHikariCP # change hikari pool name,default HikariPool-1
  jpa:
    database-platform: org.hibernate.dialect.MySQL5InnoDBDialect
    show-sql: true
    hibernate:
      ddl-auto: update

server:
  port: 8081
user:
  id: 2
配置用户信息 AuditorAware T是泛型,可以自定义
/**
 * @author whh
 * @date 2019/3/21 9:05
 */
@Component
public class User implements AuditorAware<Long> {


    @Value("${user.id:1}")
    private Long userId;


    @Override
    public Optional<Long> getCurrentAuditor() {
        return Optional.of(userId);
    }
}

配置基类
/**
 * @author whh
 * @date 2019/3/21 9:09
 */
@Data
@EntityListeners(AuditingEntityListener.class)
@MappedSuperclass
public class BaseModel {


    /**
     * 主键ID,根据数据库策越选择生成ID方式
     */
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    /**
     * 表示该字段为创建人,在这个实体被insert的时候,会自动为其赋值
     */
    @CreatedBy
    @Column(name = "create_by",nullable = false)
    private Long createBy;

    /**
     * 表示该字段为创建时间字段,在这个实体被insert的时候,会自动为其赋值
     */
    @CreatedDate
    @Column(name = "create_time", nullable = false)
    private Date createTime;

    /**
     * 表示该字段为修改人,在这个实体被update的时候,会自动为其赋值
     */
    @LastModifiedBy
    @Column(name = "last_update_by", nullable = false)
    private Long lastUpdateBy;

    /**
     * 表示该字段为修改时间字段,在这个实体被update的时候,会自动为其赋值
     */
    @LastModifiedDate
    @Column(name = "last_update_time", nullable = false)
    private Date lastUpdateTime;
}
配置实体类
**
 * @author whh
 * @date 2019/3/21 9:10
 */
@Table(name = "person")
@Entity
@Data
@org.hibernate.annotations.Table(appliesTo = "person", comment = "人员表")
public class Person extends BaseModel {
    private String name;
    private String sex;
    private Integer age;
}

这里@DATA注解是lombok包的注解,需要引用lombak插件 会自动生成get方法set方法
在这里插入图片描述

启动类配置

@EnableJpaAuditing
@SpringBootApplication
public class DemoApplication {

    public static void main(String[] args) {
        SpringApplication.run(DemoApplication.class, args);
    }

}
repository

/**
 * @author whh
 * @date 2019/3/21 9:13
 */
@Repository
public interface PersonRepository extends JpaRepository<Person, Long> {
}
测试类

@RunWith(SpringRunner.class)
@SpringBootTest
public class DemoApplicationTests {

    @Autowired
    private PersonRepository personRepository;

    @Test
    public void contextLoads() {

        Person person = new Person();
        person.setAge(19);
        person.setName("whh");
        person.setSex("男");
        personRepository.save(person);

    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值