点击访问:JPA环境配置(一)

Persistence:

Persistence用于获取EntityManagerFactory实例,这个类中包含一个名为createEntityManagerFactory的静态方法。

这个方法有两个重载的版本:

1)带有一个参数的方法以JPA配置文件中的持久化单元名为参数。

  1. <persistence-unit name="JpaDemo1" transaction-type="RESOURCE_LOCAL">

就是这个JpaDemo1

2)带有两个参数的方法:第一个参数和第一种版本一样,第二个参数传下去的是个Map集合,这个集合可以用来设置JPA的配置。

EntityManagerFactory:

这个接口主要是用来创建EntityManager实例对象,这个接口中约束了4个方法。

createEntityManager():用于创建实体管理器对象的实例

createEntityManager(Map map):map参数用于提供EntityManager的属性

isOpen():用来检测EntityManagerFactory对象是否关闭,在工厂打开之后除非调用close()才会关闭

close():上面也说了,关闭工厂用的,关闭之后在使用抛出异常IllegalStateException

EntityManager:

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

实体的状态分为:

1)新建状态:新创建的对象,还没拥有持久化主键

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

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

4)删除状态:拥有持久化主键,已经和持久化建立上下文,但是数据库的已经被删除。

现在测试下这个类中的方法如何使用。

find(Class<T> entityClass , Object primaryKey)

第一个参数 entityClass是持久化类的class对象,第二个参数是主键ID,同hibernate种get()方法,一旦执行立即加载,立马发送语句

  1. //获取持久化对象,立即发送sql语句,没有查到对应的数据返回null
  2. Student student = entityManager.find(Student.class, 1);
  3. System.out.println(student);

getReference(Class<T> entityClass , Object primaryKey)

第一个参数 entityClass是持久化类的class对象,第二个参数是主键ID。同hibernate中load()方法,即使执行使用才加载,使用才发送语句

  1. @Test
  2. public void test3(){
  3. //获取持久化对象,延迟加载使用才发送sql语句,没有查询到对应于的数据抛出异常
  4. Student student = entityManager.getReference(Student.class,1);
  5. System.out.println(student);
  6. }

persist(Object entity)

用于将新建对象纳入到EntitiyManager的管理,该方法执行后这个对象将变成持久化对象。如果对已经处于持久化的对象进行管理那么这个方法什么都不会做,将删除状态的对象传入会将这个对象给持久化。如果将游离状态的对象传入可以抛出异常。

  1. //将新建对象转换为持久化对象
  2. Student student = new Student("AA", "AA-00", 11, "13212341234", "中国-未知-未知");
  3. entityManager.persist(student);

remove(Object entity)

删除实例,只能删除持久化对象同Hibernate。

  1. @Test
  2. public void test5(){
  3. //删除一个持久化对象,数据库对应记录会对应删除
  4. Student student = entityManager.find(Student.class,1);
  5. entityManager.remove(student);
  6. }

createQuery(String hqString)

创建一个查询对象

  1. @Test
  2. public void createQuery(){
  3. //创建一个查询对象
  4. String hql = "from Student";
  5. Query query = entityManager.createQuery(hql);
  6. List<Student> students = query.getResultList();
  7. for (Student student : students) {
  8. System.out.println(student);
  9. }
  10. }

createNamedQuery(String nameString)

根据命名的查询语句块创建查询对象。参数为命名的查询语句。

createNativeQuery (String sqlString):

使用标准 SQL语句创建查询对象。参数为标准SQL语句字符串。

  1. @Test
  2. public void createNativeQuery(){
  3. //使用标准 SQL语句创建查询对象。参数为标准SQL语句字符串。
  4. String sql = "select * from tal_student";
  5. Query query = entityManager.createNativeQuery(sql,Student.class);
  6. List<Student> students = query.getResultList();
  7. for (Student student : students) {
  8. System.out.println(student);
  9. }
  10. //createNativeQuery (String sqls, String resultSetMapping)
  11. //使用标准SQL语句创建查询对象,并指定返回结果集 Map的 名称。
  12. }

merge(T entity)

同HIbernate saveOrUpdate方法,用于持久化对象同步如果没有就Insert 如果有就执行update

flush()

同步持久上下环境意思就是将持久上下文所有没有保存的数据更新到数据库

refresh()

用于更新实体记录的数据
contains(Object entity)

判断一个对象是否是持久化对象

isOpen()

判断实体管理器是否打开

getTransaction()

返回资源层事务对象。

close()

关闭这个实体管理器

EntityTransaction

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

这里面有几个常用的方法和hibernate中Transaction都是一样的。

Begin()启动一个事务,如果这个事物已经启动抛出一个异常

commit()提交一个事物,提交之后将增删改操作更新至数据库

rollback()回滚一个数据,回滚后所有的操作将失效。

注意我上面那些操作代码使用的是单元测试,@Before中就已经初始化工厂与实体管理器,在@After中对事物进行过提交与资源关闭,没提交事务,上面那些增删改操作都是失效操作。

JPA核心类与使用的更多相关文章

  1. cesium核心类Viewer简介

    1.简单描述Viewer Viewer类是cesium的核心类,是地图可视化展示的主窗口,cesium程序应用的切入口,扮演必不可少的核心角色. 官网的英文解析如下: A base widget fo ...

  2. Webwork 学习之路【03】核心类 ServletDispatcher 的初始化

    1. Webwork 与 Xwork 搭建环境需要的的jar 为:webwork-core-1.0.jar,xwork-1.0.jar,搭建webwork 需要xwork 的jar呢?原因是这样的,W ...

  3. Hibernate核心类用法-使用Transaction管理事务

    一个典型的事务应该使用下面的形式 在创建完Session对象后即使用beginTransaction()启动事务 从此开始直到commit()之间的代码 都会处于同一个事务中 这两个函数之间所有的数据 ...

  4. 理解Lucene索引与搜索过程中的核心类

    理解索引过程中的核心类 执行简单索引的时候需要用的类有: IndexWriter.ƒDirectory.ƒAnalyzer.ƒDocument.ƒField 1.IndexWriter IndexWr ...

  5. android的消息处理有三个核心类:Looper,Handler和Message。

    android的消息处理机制(图+源码分析)——Looper,Handler,Message   作为 一名android程序员,我学习android的一大乐趣是可以通过源码学习google大牛们的设 ...

  6. codeigniter框架扩展核心类---实现前台后台视图的分离

    1. 扩展核心类,主要作用就是扩展系统现在的功能. 为前台增加独立的视图文件夹: a. 自定义路径常量 :在application ->config/  constants.php中增加 /*m ...

  7. Activiti源码分析(框架、核心类。。。)

    http://jiangwenfeng762.iteye.com/blog/1338553 Activiti是业界很流行的java工作流引擎,关于Activiti与JBPM5的关系和如何选择不是本文要 ...

  8. Spring Security——核心类简介——获得登录用户的相关信息

    核心类简介 目录 1.1     Authentication 1.2     SecurityContextHolder 1.3     AuthenticationManager和Authenti ...

  9. lucene原理及源码解析--核心类

    马云说:大家还没搞清PC时代的时候,移动互联网来了,还没搞清移动互联网的时候,大数据时代来了. 然而,我看到的是:在PC时代搞PC的,移动互联网时代搞移动互联网的,大数据时代搞大数据的,都是同一伙儿人 ...

随机推荐

  1. 第25月第17天 django rest framwork authentication /tmp/mysql.sock

    1.authentication https://www.django-rest-framework.org/api-guide/authentication/#authentication 2.dj ...

  2. 《从Paxos到Zookeeper:分布式一致性原理与实践》第一章读书笔记

    第一章主要介绍了计算机系统从集中式向分布式系统演变过程中面临的挑战,并简要介绍了ACID.CAP和BASE等经典分布式理论,主要包含以下内容: 集中式的特点 分布式的特点 分布式环境的各种问题 ACI ...

  3. bind,unbind,one

    刚开始我们先看一下它的定义: .bind( eventType [, eventData], handler(eventObject)) .Bind()方法的主要功能是在向它绑定的对象上面提供一些事件 ...

  4. no plugin found for prefix 'tomcat 7' in the current project

    使用maven build编译出错 “no plugin found for prefix 'tomcat 7' in the current project..........” 参照下面方法 ht ...

  5. Xml的转义字符--约束-xml解析器

    XML解析器:Dom适合增删改查(crud),缺点就是内存消耗大:  Sax:内存消耗非常小,解析速度快,但是不适合增删改:

  6. Django学习手册 - Form 插件

    """ 核心: from django import formsfrom django.forms import fieldsfrom django.forms impo ...

  7. 自定义gradle插件

    重点学习https://www.jianshu.com/p/804d79415258 https://blog.csdn.net/l2show/article/details/53925543 htt ...

  8. CentOS7下安装JDK详细过程

    Linux上一般会安装Open JDK,关于OpenJDK和JDK的区别:http://www.cnblogs.com/sxdcgaq8080/p/7487369.html 下面开始安装步骤: --- ...

  9. openstack Q版部署-----Cinder云存储服务(10)

    一.cinder介绍 一般 cinder-api 和 cinder-scheduler 安装在控制节点上, cinder-volume 安装在存储节点上. 二.数据库配置 # 在任意控制节点创建数据库 ...

  10. python,异常处理

    # 该例子是对文件异常和类型异常分别进行的处理 try: sum = 1+' f=open('wo.txt') print(f.read()) f.close() except OSError as ...