1、

Persistence

EntityManagerFactory

2、

EntityManager#find

EntityManager#getReference

EntityManager#persistence

EntityManager#remove

3、

EntityTransaction(事物)

4、EntityManager 其他方法

5、EntityManager#merge

1、JPA相关接口/类:Persistence

.Persistence 类是用于获取 EntityManagerFactory 实例。该类包含一个名为 createEntityManagerFactory 的 静态方法 。

.createEntityManagerFactory 方法有如下两个重载版本。 带有一个参数的方法以 JPA 配置文件 persistence.xml 中的持久化单元名为参数 带有两个参数的方法:前一个参数含义相同,后一个参数 Map类型,用于设置 JPA 的相关属性,这时将忽略其它地方设置的属性。Map 对象的属性名必须是 JPA 实现库提供商的名字空间约定的属性名。

2、EntityManagerFactory

EntityManagerFactory 接口主要用来创建 EntityManager 实例。该接口约定了如下4个方法:

<1>createEntityManager():用于创建实体管理器对象实例。

<2>createEntityManager(Map map):用于创建实体管理器对象实例的重载方法,Map 参数用于提供 EntityManager 的属性。

<3>isOpen():检查 EntityManagerFactory 是否处于打开状态。实体管理器工厂创建后一直处于打开状态,除非调用close()方法将其关闭。

<4>close():关闭 EntityManagerFactory 。 EntityManagerFactory 关闭后将释放所有资源,isOpen()方法测试将返回 false,其它方法将不能调用,否则将导致IllegalStateException异常。

4、EntityManager

在 JPA 规范中, EntityManager 是完成持久化操作的核心对象。实体作为普通 Java 对象,只有在调用 EntityManager 将其持久化后才会变成持久化对象。EntityManager 对象在一组实体类与底层数据源之间进行 O/R 映射的管理。它可以用来管理和更新 Entity Bean, 根椐主键查找 Entity Bean, 还可以通过JPQL语句查询实体。

实体的状态: 新建状态: 新创建的对象,尚未拥有持久性主键。

持久化状态:已经拥有持久性主键并和持久化建立了上下文环境

游离状态:拥有持久化主键,但是没有与持久化建立上下文环境

删除状态: 拥有持久化主键,已经和持久化建立上下文环境,但是从数据库中删除。

find (Class<T> entityClass,Object primaryKey):

返回指定的 OID 对应的实体类对象,如果这个实体存在于当前的持久化环境,则返回一个被缓存的对象;否则会创建一个新的 Entity, 并加载数据库中相关信息;若 OID 不存在于数据库中,则返回一个 null。第一个参数为被查询的实体类类型,第二个参数为待查找实体的主键值。

getReference (Class<T> entityClass,Object primaryKey):

与find()方法类似,不同的是:如果缓存中不存在指定的 Entity, EntityManager 会创建一个 Entity 类的代理,但是不会立即加载数据库中的信息,只有第一次真正使用此 Entity 的属性才加载,所以如果此 OID 在数据库不存在,getReference() 不会返回 null 值, 而是抛出EntityNotFoundException

persist (Object entity):

用于将新创建的 Entity 纳入到 EntityManager 的管理。该方法执行后,传入 persist() 方法的 Entity 对象转换成持久化状态。

--如果传入 persist() 方法的 Entity 对象已经处于持久化状态,则 persist() 方法什么都不做。

--如果对删除状态的 Entity 进行 persist() 操作,会转换为持久化状态。

--如果对游离状态的实体执行 persist() 操作,可能会在 persist() 方法抛出 EntityExistException(也有可能是在flush或事务提交后抛出)。

remove (Object entity)

删除实例。如果实例是被管理的,即与数据库实体记录关联,则同时会删除关联的数据库记录。

merge (T entity):merge() 用于处理 Entity 的同步。即数据库的插入和更新操作

EntityTransaction(事物管理)

EntityTransaction 接口用来管理资源层实体管理器的事务操作。通过调用实体管理器的getTransaction方法 获得其实例。

begin ()

----用于启动一个事务,此后的多个数据库操作将作为整体被提交或撤消。若这时事务已启动则会抛出 IllegalStateException 异常。

commit ()

----用于提交当前事务。即将事务启动以后的所有数据库更新操作持久化至数据库中。

rollback ()

-----撤消(回滚)当前事务。即撤消事务启动后的所有数据库更新操作,从而不对数据库产生影响。

setRollbackOnly ()

-----使当前事务只能被撤消。

getRollbackOnly ()

----查看当前事务是否设置了只能撤消标志。

isActive ()

-----查看当前事务是否是活动的。如果返回true则不能调用begin方法,否则将抛出 IllegalStateException 异常;

如果返回 false 则不能调用 commit、rollback、setRollbackOnly 及 getRollbackOnly 方法,否则将抛出 IllegalStateException 异常。

相关测试代码:

package com.jpa.test;

import java.util.Date;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.EntityTransaction;
import javax.persistence.Persistence; import org.junit.After;
import org.junit.Before;
import org.junit.Test; import com.guigu.jpa.helloword.Customer; public class JPATest {
private EntityManagerFactory entityManagerFactory;
private EntityManager entityManager;
private EntityTransaction transaction;
@Before
public void init(){
entityManagerFactory= Persistence.createEntityManagerFactory("jpa-1");
entityManager=entityManagerFactory.createEntityManager();
transaction=entityManager.getTransaction();
transaction.begin();//开启事务 }
@After
public void destroy(){
transaction.commit();
entityManager.close();
entityManagerFactory.close();
} /**
* 若传入得是一个游离状态的对象,即传入的对象有OID
* 1、若在EntityManager缓存中有该对象
* 2、JPA会把游离状态的属性复制到EntityManager缓存中的对象中
* 3、EntityManager缓存中的对象象执行update
*/
@Test
public void testMerge4(){
Customer customer=new Customer();
customer.setAge();
customer.setBirth(new Date());
customer.setCreatedTime(new Date());
customer.setEmail("dd@163.com");
customer.setLastName("DD");
customer.setId(); Customer customer2=entityManager.find(Customer.class, ); entityManager.merge(customer);
System.out.println(customer==customer2);//false } /**
* 若传入得是一个游离状态的对象,即穿入的对象有OID
* 1、若在EntityManager缓存中没有该对象
* 2、若在数据库中有改记录
* 3JPA会查询对应的记录,然后返回该记录对应的一个对象,再然后会把游离对象的属性复制到查询到的对象中
* 4、对查询到的对象执行update操作
*/
@Test
public void testMerge3(){
Customer customer=new Customer();
customer.setAge();
customer.setBirth(new Date());
customer.setCreatedTime(new Date());
customer.setEmail("ee@163.com");
customer.setLastName("EE");
customer.setId();
Customer customer2=entityManager.merge(customer);
System.out.println(customer==customer2);//false } /**
* 若传入得是一个游离状态的对象,即穿入的对象有OID
* 1、若在EntityManager缓存中没有该对象
* 2、若在数据库中也没有改记录
* 3JPA会创建一个新对象,然后把前游离对象的属性复制到新创建的对象中
* 4、对新创建的对象执行insert操作
*/
@Test
public void testMerge2(){
Customer customer=new Customer();
customer.setAge();
customer.setBirth(new Date());
customer.setCreatedTime(new Date());
customer.setEmail("hello@163.com");
customer.setLastName("李四");
customer.setId();
Customer customer2=entityManager.merge(customer);
System.out.println("customer#id"+customer.getId());
System.out.println("customer2#id"+customer2.getId()); } /*
* 总的来说:类似于hibernate session 的saveOrUpdate方法
* 1.若传入得是一个临时对象则会创建一个新对象,把零时对象的属性复制到新对象中,然后对新对象执行持久化操作
* 所以新的对象有id,但是以前的零时对象中没有id
*/
@Test
public void testMerge1(){
Customer customer=new Customer();
customer.setAge();
customer.setBirth(new Date());
customer.setCreatedTime(new Date());
customer.setEmail("hello@163.com");
customer.setLastName("李四"); Customer customer2=entityManager.merge(customer);
System.out.println("customer#id"+customer.getId());
System.out.println("customer2#id"+customer2.getId()); }
//类似于hibernated的delete方法,把对象对应的记录从数据库中移除
//但注意:该方法只能移除持久化对象,而hibernate的delete方法实际上还可以移除游离对象
@Test
public void testRemove(){
// Customer customer =new Customer();
// customer.setId(2);
Customer customer=entityManager.find(Customer.class, );
entityManager.remove(customer); } //类似于hibernate的save方法使对象由临时状态转变为持久化状态
//和hibernatede save方法不同之处:对象由id则不能执行insert操作,会抛出异常
@Test
public void testPersistence(){
Customer customer=new Customer();
customer.setAge(); customer.setBirth(new Date());
customer.setCreatedTime(new Date());
customer.setEmail("@123456.conm");
customer.setLastName("张三");
// customer.setId(100);//hi抛出异常
entityManager.persist(customer);
System.err.println(customer.getId()); } //类似于hibernate 中的session中的load方法
@Test
public void testGetReference(){
Customer customer=entityManager.getReference(Customer.class, );//1表示id
System.out.println(customer.getClass().getName());
System.out.println("-------------------------------");
// transaction.commit();
// entityManagerFactory.close();
System.out.println(customer); }
//类似于hibernate 中的session中的get方法
@Test
public void testFind(){
Customer customer=entityManager.find(Customer.class, );//1表示id
System.out.println("-------------------------------");
System.out.println(customer); } }

完整 源码地址:https://github.com/wuhongpu/JPA.git

 

JPA(API)的更多相关文章

  1. JPA API与注解

    一.JPA API Persistence 类:用于获取 EntityManagerFactory 实例,该类含有静态方法 createEntityManagerFactory. //persiste ...

  2. JPA学习(3)JPA API

    在我们的jpa的helloworld中,我们看到了简单的一个jpa保存操作,下面就来好好学习一下,JPA最主要的几个类 1.基本的几个类: ①:Persistence 类是用于获取 EntityMan ...

  3. jpa

    学习尚硅谷jpa笔记: 所依赖的jar包: 首先在META-INF下创建配置文件,persistence.xml <?xml version="1.0" encoding=& ...

  4. JPA persistence

    Play provides a set of very useful helpers to simplify the management of your JPA entities. Note tha ...

  5. Java Persistence API(转)

    定义 Java Persistence API JPA通过JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中.[编辑本段]起源 Sun引入新的JPA ORM规范 ...

  6. 什么是JPA

    起源 JPA由EJB 3.0软件专家组开发,作为JSR-220实现的一部分.但它不囿于EJB 3.0,你可以在Web应用.甚至桌面应用中使用.JPA的宗旨是为POJO提供持久化标准规范,由此可见,经过 ...

  7. JPA使用的HelloWorld

    一.使用JPA持久化对象的步骤 •创建 persistence.xml, 在这个文件中配置持久化单元 –需要指定跟哪个数据库进行交互; –需要指定 JPA 使用哪个持久化的框架以及配置该框架的基本属性 ...

  8. Hibernate与JPA的区别是什么

    翻译来源:https://www.quora.com/What-is-the-difference-between-Hibernate-and-JPA 本文作者:苏生米沿 本文地址:http://bl ...

  9. Native Hibernate与Hibernate JPA

    本文作者:苏生米沿 本文地址:http://blog.csdn.net/sushengmiyan/article/details/50182005 翻译来源:http://stackoverflow. ...

随机推荐

  1. 激光相机数据融合(5)--Gazebo仿真数据融合

    这一节将用ROS+Gazebo 环境获取激光获取点云,并用PCL和OPENCV处理,源代码在:https://github.com/ZouCheng321/5_laser_camera_sim 由于激 ...

  2. centos7下部署Django(nginx+uwsgi+python3+django)

    系统版本 centos7 python版本 使用官方python3.6.3正式版 django版本 使用本文发布时最新的1.11.7 uwsgi版本 使用本文发布时最新的2.0.15 nginx版本 ...

  3. (译)学习JavaScript闭包

    原文地址:https://medium.freecodecamp.org/lets-learn-javascript-closures-66feb44f6a44   闭包是JavaScript中一个基 ...

  4. 设置SO_RECVBUF和SO_SENDBUF套接字选项

    控制套接字的行为(如修改缓冲区的大小). int getsockopt(int sockfd,int level,int optname,void *optval,socklen_t *optlen) ...

  5. redis—操作基础

    内存数据库: 1.双击redis-server.exe =>启动2.双击redis-cli.exe =>打开管理控制台3.查看所有key keys *4.查看key类型 type myKe ...

  6. Mysql基础--表的操作

    1.表的基本概念 每一行代表一条唯一的记录,每一列代表记录中的一个字段. 2.创建表 例子: 3.查看表结构 (1)DESCRIBE语句查看表定义 语法: 例子: (2)SHOW CREATE TAB ...

  7. 【转】《高级前端3.6》JavaScript多线程——Concurrent.Thread.js, WebWork

    原文链接:http://www.cnblogs.com/woodk/articles/5199536.html JavaScript多线程,在HTML5 WebWork没出现之前很多人都是用Concu ...

  8. 简单了解enum

    enum的性质: 1.枚举类型的实例都是常量 2.要使用enum,需要创建一个该类型的引用,并将其赋值给某个实例 3.常用的方法:  *     toString():某个enum实例的名字  *   ...

  9. 前端测试框架Jest系列教程 -- 简介

    写在前面: 随着互联网日新月异的发展,用户对于页面的美观度,流畅度以及各方面的体验有了更高的要求,我们的网页不再是简单的承载文字,图片等简单的信息传递给用户,我们需要的是更加美观的页面展示,更快的浏览 ...

  10. 关于verilog中语句可不可综合

    1)所有综合工具都支持的结构:always,assign,begin,end,case,wire,tri,aupply0,supply1,reg,integer,default,for,functio ...