JPA核心类与使用(二)
Persistence:
Persistence用于获取EntityManagerFactory实例,这个类中包含一个名为createEntityManagerFactory的静态方法。
这个方法有两个重载的版本:
1)带有一个参数的方法以JPA配置文件中的持久化单元名为参数。
<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()方法,一旦执行立即加载,立马发送语句
//获取持久化对象,立即发送sql语句,没有查到对应的数据返回null Student student = entityManager.find(Student.class, 1); System.out.println(student);
getReference(Class<T> entityClass , Object primaryKey)
第一个参数 entityClass是持久化类的class对象,第二个参数是主键ID。同hibernate中load()方法,即使执行使用才加载,使用才发送语句
@Test public void test3(){ //获取持久化对象,延迟加载使用才发送sql语句,没有查询到对应于的数据抛出异常 Student student = entityManager.getReference(Student.class,1); System.out.println(student); }
persist(Object entity)
用于将新建对象纳入到EntitiyManager的管理,该方法执行后这个对象将变成持久化对象。如果对已经处于持久化的对象进行管理那么这个方法什么都不会做,将删除状态的对象传入会将这个对象给持久化。如果将游离状态的对象传入可以抛出异常。
//将新建对象转换为持久化对象 Student student = new Student("AA", "AA-00", 11, "13212341234", "中国-未知-未知"); entityManager.persist(student);
remove(Object entity)
删除实例,只能删除持久化对象同Hibernate。
@Test public void test5(){ //删除一个持久化对象,数据库对应记录会对应删除 Student student = entityManager.find(Student.class,1); entityManager.remove(student); }
createQuery(String hqString)
创建一个查询对象
@Test public void createQuery(){ //创建一个查询对象 String hql = "from Student"; Query query = entityManager.createQuery(hql); List<Student> students = query.getResultList(); for (Student student : students) { System.out.println(student); } }
createNamedQuery(String nameString)
根据命名的查询语句块创建查询对象。参数为命名的查询语句。
createNativeQuery (String sqlString):
使用标准 SQL语句创建查询对象。参数为标准SQL语句字符串。
@Test public void createNativeQuery(){ //使用标准 SQL语句创建查询对象。参数为标准SQL语句字符串。 String sql = "select * from tal_student"; Query query = entityManager.createNativeQuery(sql,Student.class); List<Student> students = query.getResultList(); for (Student student : students) { System.out.println(student); } //createNativeQuery (String sqls, String resultSetMapping) //使用标准SQL语句创建查询对象,并指定返回结果集 Map的 名称。 }
merge(T entity)
同HIbernate saveOrUpdate方法,用于持久化对象同步如果没有就Insert 如果有就执行update
flush()
同步持久上下环境意思就是将持久上下文所有没有保存的数据更新到数据库
refresh()
用于更新实体记录的数据
contains(Object entity)
判断一个对象是否是持久化对象
isOpen()
判断实体管理器是否打开
getTransaction()
返回资源层事务对象。
close()
关闭这个实体管理器
EntityTransaction
接口用来管理资源层实体管理器的事务操作。通过调用实体管理器的getTransaction方法 获得其实例。
这里面有几个常用的方法和hibernate中Transaction都是一样的。
Begin()启动一个事务,如果这个事物已经启动抛出一个异常
commit()提交一个事物,提交之后将增删改操作更新至数据库
rollback()回滚一个数据,回滚后所有的操作将失效。
注意我上面那些操作代码使用的是单元测试,@Before中就已经初始化工厂与实体管理器,在@After中对事物进行过提交与资源关闭,没提交事务,上面那些增删改操作都是失效操作。