设置默认值
@Column(name="state",columnDefinition="tinyint default 0")
private Integer state=0;
columnDefinition在创建表的时候使用
其他时候可以采用直接赋值的方式:
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启动类加注解