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;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值