Java JPA设置默认值、Timestamp设置、自动获取时间

  • Post author:
  • Post category:java


写在开头

本文为转载专题,转载:

Java JPA设置默认值、Timestamp设置、自动获取时间_gmHappy的博客-CSDN博客_jpa timestamp

设置默认值

@Column(name="state",columnDefinition="tinyint default 0")
private Integer state=0;

columnDefinition在创建表的时候使用

其他时候可以采用直接赋值的方式:

private Integer state=0;

Timestamp设置

注解


@org.hibernate.annotations.Generated


来标识一个已生成属性

@Column(name="CREATE_TIME",columnDefinition="TIMESTAMP DEFAULT CURRENT_TIMESTAMP",insertable = false,updatable = false)
@Generated(GenerationTime.INSERT)
private Timestamp createTime;

GenerationTime的可用的设置选项是


ALWAYS





INSERT

使用GenerationTime.ALWAYS的时候,Hibernate每次执行SQL UPADATE或者INSERT插入的时候就会刷新实体

使用GenerationTime.INSERT,只会在SQL INSERT的时候出现,来获取数据库的默认值

属性也应该标识为只读,只读属性使用注解@Column的updatable和insertable来实现

如果


两个都设置了false


,属性列表就用于不会在INSERT或者UPADATE语句中出现了,


这些列的数值就由数据库来产生值

@ColumnDefault属性注解,设置列表的默认属性,当hibernate导出和生成SQL schenma DDL的时候

@Temporal注解来声明映射的SQL数据类型,如果使用了converter转换器之后,注解是不需要了

@Column(columnDefinition=”timestamp default current_timestamp comment ‘活动开始时间'”)可以设置默认值、可以生成注释

自动创建时间、修改时间

1.实体类加注解

/**
 * 创建时间
 */
@CreatedDate
@Column(name = "create_time")
private Date createTime;

/**
 * 修改时间
 */
@LastModifiedDate
@Column(name = "modify_time")
private Date modifyTime;

2.实体类头加注解

@EntityListeners(AuditingEntityListener.class)

3.SpringBoot启动类加注解

@EnableJpaAuditing

要加这三个群的+微信好友:LTingUY1024(备注想加的群)



禁培训机构、禁广告推销、禁非IT行业招聘,求职。


此群的意义在于 方便成都地区IT招聘兼职、私活、学习、求职使用。

本人也将不定时的发布招聘JAVA、前端、UI等IT相关的兼职、私活工作,欢迎大家加入。