@Entity(name=”T_TEST”)
public class Test implements Serializable{
@Id
@GeneratedValue(strategy=GenerationType.TABLE)
@Column(name=” id”)
private int testId;
@Column(name=”uname”,length=100)
private String uname;
@Column(name=”password”)
private String password;
@Column(name=”time”)
@Temporal(TemporalType.Date)
private Date loginTime;
省略get/setter方法
}
下面对以上代码中所涉及的JPA注解进行一下说明
@Entity:将领域对象标注为一个实体类,表示该类需要持久化到数据库中,默认情况下类名即表名,通过name属性显式指定表名,如:name=”T_TEST”表示将Test保存到表T_TEST表中。
@Id:对应的属性是表的主键
@GeneratedValue:主键的产生策略,通过strategy属性进行指定,默认情况下,JPA自动选择一个最适合底层数据库的主键生成策略,如SqlServer对应的identity:mysql对应的auto increment,在java.persistence.GenerationType中定义了几种可以供选择的策略:
1. Identity:表自动增长字段,Oracle不支持这种方式;
2. AUTO:JPA自动选择合适的策略,是默认选项;
3. Sequence:通过序列产生主键,通过@SequenceGenerator注解指定序列名,Mysql不支持这种方式。
4. TABLE:通过表产生主键,框架借由表模拟产生主键,使用该策略可以使用更易于数据库的移植。
@Colunm(name=”uname”):属性对应的表字段。我们并不需要指定表字段的类型,因为JPA 会根据反射从实体属性中获取类型;如果是字符串类型,我们可以指定字段长度,以便可以自动生成DDL语句。
@Temporal(TemporalType.DATE):如果属性是时间类型,因为数据表对时间类型有更严格的划分,所以必须指定具体时间类型,在java.persistence.TemporalType枚举中定义了三种时间类型:
Date:等于java.sql.Date;
Time:等于java.sql.Time;
TimeStamp:等于java.sql.Timestamp。
JPA对于具有父子关系的类,对于父类必须声明继承实体的映射策略,对于继承实体,java.persistence.InheritanceType定义了3种映射策略:
SINGLE_TABLE:父子类都保存在同一个表中,通过字段值进行区分。
JOINED:父子类相同的部分保存在同一个表中,不同的部门分开存放,通过连接不同的表获取完整数据。
TABLE_PER_CLASS:每一个类对应自己的表,一般不推荐采用这种方式。
下面我们来看看实际的列子是怎么运用的。
父类Test
@Entity(name=”test”)
@Inheritance(strategy=InheritanceType.SINGLE_TABLE)//指定继承策略
@DiscriminatorColumn(name=”types”,discriminatorType=DiscriminatorType.INTEGER,length=1)//指定区分字段为types,类型为Integer长度为1
@DiscriminatorValue(value=”1”)//对应具体实体的值
public class Test implements Serializable{
…..
}
子类Child
@Entity
@DiscriminatorValue(value=”2”)
public class Child extends Test{
//如果我们不希望JPA将该属性持久化到数据库,则采用该注解
@Transient
private String tempStr;
@Lob //lob类型的字段
@Basic(fetch=FetchType.Lazy) //采用延迟加载,FetchType.EAGER不采用
@Column(name=”postattach”,columnDefinition=”LONGTEXT NOT NULL”)对应字段类型
private String postAttach;
}
可以看到通过字段types来区分父子类数据,也是相当方便的。至于JPA提供的关联关系比如说一对多,多对一,多对多,也有相应的注解进行关联,有兴趣的朋友可以参考相关帮助文档。