设置默认值
@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​

当使用​ ​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