概述
JPA:Java Persistence API,用于对象持久化的API
Java EE 5.0平台标准的ORM规范,使得应用程序以统一的方式访问持久层
JPA和Hibernate的关系
JPA是规范,JPA实质上就是一种ORM规范,不是ORM框架——因为JPA并未提供ORM实现,它只是制定了一些规范,提供了一些编程的API接口,但具体实现则由ORM厂商提供实现
JPA的供应商
JPA的目标之一是制定一个可以由很多供应商实现的API,目前Hibernate 3.2+、TopLink 10.1+以及OpenJPA都提供了JPA的实现
JPA包括3方面的技术
- ORM映射元数据:JPA支持XML和JDK 5.0注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象
- 持久化到数据库表中。
- JPA的API:用来操作实体对象,执行CRUD操作,框架在后台完成所有事情,开发者从频繁的JDBC和SQL代码中解脱出来。
- 查询语言(JPQL):这是持久化操作中很重要的一个方面,通过面向对象而非面向数据库的查询语言查询数据,避免程序和具体的SQL紧密耦合。
基础配置
步骤
- 配置persistence.xml,persistence.xml位于META-INF目录下
- 创建实体类,使用annotation来描述实体类跟数据库表之间的映射关系
- 使用JPA API完成数据增删改查操作(EntityManager)
需要用到的jar包
- antlr-2.7.7.jar
- dom4j-1.6.1.jar
- hibernate-commons-annotations.jar
- hibernate-core-4.2.4.Final.jar
- hibernate-entitymanager-4.2.3.Final.jar
- hibernate-jpa-2.0-api-1.0.1.Final.jar
- javassist-3.15.0-GA.jar
- jboss-logging-3.1.0.GA.jar
- jboss-transaction-api_1.1_spec-1.0.jar
- mysql-connector-java-5.1.7.bin.jar
配置persistence.xml
<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.0"
xmlns="http://java.sun.com/xml/ns/persistence"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
http://java.sun.com/xml/ns/persistence/persistence_2_0.xsd">
<persistence-unit name="jpa-01">
<!-- 配置是用什么ORM产品作为JPA的实现 1. 实际上配置的是javax.persistence.spi.PersistenceProvider接口的实现类
2. 若JPA项目中只有一个JPA的实现产品,则也可以不配置该节点 -->
<provider>org.hibernate.ejb.HibernatePersistence</provider>
<class>com.iuie.jpa.entity.Customer</class>
<properties>
<!-- 连接数据库的基本信息 -->
<property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver" />
<property name="javax.persistence.jdbc.url" value="jdbc:mysql:///ns" />
<property name="javax.persistence.jdbc.user" value="root" />
<property name="javax.persistence.jdbc.password" value="123456" />
<!-- 配置JPA实现产品的基本属性,配置hibernate的基本属性 -->
<property name="hibernate.format_sql" value="true" />
<property name="hibernate.show_sql" value="true" />
<property name="hibernate.hbm2ddl" value="update" />
</properties>
</persistence-unit>
</persistence>
常用注解
@GeneratedValue注解
作用
用于标注主键的生成策略,通过strategy属性指定。默认情况下,JPA自动选择一个最适合底层数据库的主键生成策略:
- SQL Server:identity
- MySQL:auto increment
在javax.persistence.GenerationType中定义了以下几种可供选择的策略:
- IDENTITY:采用数据库ID自增长的方式来自增主键字段,Oracle不支持这种方式
- AUTO:JPA自动选择合适的策略,是默认选项
- SEQUENCE:通过序列产生主键,通过@SequenceGenerator注解指定程序名,MySQL不支持这种方式
- TABLE:通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植
@Column注解
作用
设置每一列的属性
属性
- name属性:用于设置映射数据库表的列名
- unique属性:指定是否允许重复值
- length属性:指定字段的长度
- nullable属性:指定是否非空
@Transient注解
作用
表示该属性并非一个到数据库表的字段的映射,ORM框架将忽略该属性如果一个属性并非数据库表的字段映射,就务必将其标示为@Transient,否则,ORM框架默认将其注解为@Basic
@Temporal注解
作用
指明日期的表达形式,value属性需要指定TemporalType的枚举值,
TemporalType 的枚举值包括:
- TemporalType.TIMESTAMP // yyyy-MM-dd HH:mm:ss形式
- TemporalType.DATE // yyyy-MM-dd形式
示例
private Date loginTime;
private Date birthday;
// yyyy-MM-dd HH:mm:ss
@Temporal(TemporalType.TIMESTAMP)
public Date getLoginTime(){
return this.loginTime;
}
public void setLoginTime(Date loginTime){
this.loginTime=loginTime;
}
// yyyy-MM-dd
@Temporal(TemporalType.DATE)
public Date getBirthday(){
return this.birthday;
}
public void setBirthday(Date birthday){
this.birthday=birthday;
}
用table来生成主键策略
(使用的情景相对较少)
步骤
- 创建一个生成主键的表:
表名:JPA_ID_GENERATOR(数据表ID生成策略表)
columnName dataType length 是否主键 是否不为空 描述
ID int 10 y y 生成表的ID
PK_NAME varchar 50 y 需要使用此策略的表名称
PK_VALUE int 10 起始值,种子
插入几个值
编写Customer.java