JPA

概述

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方面的技术

  1. ORM映射元数据:JPA支持XML和JDK 5.0注解两种元数据的形式,元数据描述对象和表之间的映射关系,框架据此将实体对象
  2. 持久化到数据库表中。
  3. JPA的API:用来操作实体对象,执行CRUD操作,框架在后台完成所有事情,开发者从频繁的JDBC和SQL代码中解脱出来。
  4. 查询语言(JPQL):这是持久化操作中很重要的一个方面,通过面向对象而非面向数据库的查询语言查询数据,避免程序和具体的SQL紧密耦合。

基础配置

步骤

  1. 配置persistence.xml,persistence.xml位于META-INF目录下
  2. 创建实体类,使用annotation来描述实体类跟数据库表之间的映射关系
  3. 使用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来生成主键策略

(使用的情景相对较少)

步骤

  1. 创建一个生成主键的表:

表名:JPA_ID_GENERATOR(数据表ID生成策略表)
columnName dataType length 是否主键 是否不为空 描述
ID int 10 y y 生成表的ID
PK_NAME varchar 50 y 需要使用此策略的表名称
PK_VALUE int 10 起始值,种子

  1. 插入几个值

  2. 编写Customer.java

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值