JPA详细说明
 @Temporal(TemporalType.DATE):如果属性是时间类型,因为数据表对时间类型有更严格的划分,所以必须指定具体时间类型,如④所示。在javax.persistence.TemporalType枚举中定义了3种时间类型:
 1) DATE :等于java.sql.Date
 2) TIME :等于java.sql.Time
 3) TIMESTAMP :等于java.sql.Timestamp



如果我们不希望将某个属性持久化到数据表中,则可以通过@Transient注解显式指定:
  @Transient
  private boolean tempProp1;

1. 基本属性映射
通过 @Basic 可以声明属性的存取策略:
@Basic(fetch=FetchType.EAGER) 即时获取(默认的存取策略)
@Basic(fetch=FetchType.LAZY) 延迟获取

通过 @Temporal 定义映射到数据库的时间精度:
@Temporal(TemporalType=DATE) 日期
@Temporal(TemporalType=TIME) 时间
@Temporal(TemporalType=TIMESTAMP) 两者兼具

使用 @Lob 映射Blob或Clob类型:根据属性类型决定
java.sql.CLOB, Character[], char[], String 将映射为 Clob
java.sql.BLOB, Byte[], byte[], serializable 将映射为 Blob

2. 列属性映射
使用 @Column 映射到列

@Column( 

name="columnName"; // 可选,列名(默认是属性名) 

boolean unique() default false; // 可选,是否在该列上设置唯一约束(默认 false) 

boolean nullable() default true; // 可选,是否可以为空 

boolean insertable() default true; // 可选,该列是否作为生成insert语句中的一列 

boolean updatable() default true; // 可选,该列是否作为生成update语句中的一列 

String columnDefinition() default ""; // 可选,为这个特定列覆盖 SQL DDL 片段(可能导致无法在不同数据库间移植) 

String table() default ""; // 可选,定义对应的表,默认为主表 

int length() default 255; // 可选,列长度 

int precision() default 0; // 可选,列十进制精度(decimal precision) 

int scale() default 0; // 可选, 列十进制数范围(decimal scale) 



public class Person { 

 @Column(name = "PERSONNAME", unique = true, nullable = false, updatable = true) 

 private String name; 


 @Column(name = "PHOTO", columnDefinition = "BLOB NOT NULL", secondaryTable="PER_PHOTO") 

 private byte[] picture; 

}




1. 基本属性映射
通过 @Basic 可以声明属性的存取策略:
@Basic(fetch=FetchType.EAGER) 即时获取(默认的存取策略)
@Basic(fetch=FetchType.LAZY) 延迟获取

通过 @Temporal 定义映射到数据库的时间精度:

@Temporal(TemporalType=DATE) 日期 

@Temporal(TemporalType=TIME) 时间 

@Temporal(TemporalType=TIMESTAMP) 两者兼具 


使用 @Lob 映射Blob或Clob类型:根据属性类型决定 

java.sql.CLOB, Character[], char[], String 将映射为 Clob 

java.sql.BLOB, Byte[], byte[], serializable 将映射为 Blob 


2. 列属性映射 

使用 @Column 映射到列 

@Column( 

name="columnName"; // 可选,列名(默认是属性名) 

boolean unique() default false; // 可选,是否在该列上设置唯一约束(默认 false) 

boolean nullable() default true; // 可选,是否可以为空 

boolean insertable() default true; // 可选,该列是否作为生成insert语句中的一列 

boolean updatable() default true; // 可选,该列是否作为生成update语句中的一列 

String columnDefinition() default ""; // 可选,为这个特定列覆盖 SQL DDL 片段(可能导致无法在不同数据库间移植) 

String table() default ""; // 可选,定义对应的表,默认为主表 

int length() default 255; // 可选,列长度 

int precision() default 0; // 可选,列十进制精度(decimal precision) 

int scale() default 0; // 可选, 列十进制数范围(decimal scale) 



public class Person { 

 @Column(name = "PERSONNAME", unique = true, nullable = false, updatable = true) 

 private String name; 


 @Column(name = "PHOTO", columnDefinition = "BLOB NOT NULL", secondaryTable="PER_PHOTO") 

 private byte[] picture; 

}