可以使用PersistenceContext注入获取容器管理实体管理器实例,如下所示:
@PersistenceContext(unitName="onjava") private EntityManager em; | 如果使用应用程序管理的实体管理器,则必须管理其生命周期。可以创建一个应用程序管理实体管理器实例,如下所示:
@PersistenceUnit(unitName="onjava") private EntityManagerFactory emf; private EntityManager em = emf.createEntityManager(); | 然后可以使用EntityManager实例在实体上执行CRUD操作。要关闭应用程序管理实体管理器实例,请在完成工作后调用em.close()方法。
如前所述,必须在事务上下文中执行涉及任何数据库更改的实体管理器操作。
下表列出了EntityManager接口的一些用于执行实体操作的关键方法。
| 方法 |
用途 |
| public void persist(Object entity); |
持久化实体实例。 |
| public <T> T merge(T entity); |
合并分离的实体实例。 |
| public void remove(Object entity); |
移除实体实例。 |
| public <T> T find(Class<T> entityClass, Object primaryKey); |
通过主键检索实体实例。 |
| public void flush(); |
使实体状态与数据库同步。 | 可以使用persist()方法持久化实体实例。例如,如果想持久化Contractor实例,请使用以下代码:
@PersistenceContext(unitName="onjava") private EntityManager em; ... Contractor pte = new Contractor(); pte.setName("Nistha") pte.setHourlyRate(new Double(100.0)); em.persist(pte); |
在持久化实体时,如果此关系的CascadeType被设置为PERSIST或ALL,则任何对关联实体的状态更改也将被持久化。除非正在使用扩展的持久上下文,否则实体将在事务终止后分离。合并操作允许将分离的实体实例与持久上下文合并;分离实体的状态将与数据库同步。这将有助于摆脱EJB 2.x中常见的数据传输对象(Data Transfer Object,DTO)反模式,因为作为POJO的实体可以在层与层之间传输。惟一的要求是实体类必须实现java.io.Serializable接口。
查询API
对实体的检索是持久性的一个重要方面。使用EJB3 JPA时,使用Java持久化查询语言(Java Persistence Query Language,JPQL)表示查询。JPQL是EJBQL的扩展,它是作为EJB 2.0规范的一部分而引入的。然而,EJB3 JPA解决了EJBQL的所有局限性,并添加了许多新特性,从而成为一种功能强大的查询语言。
JPQL较之EJBQL 2.x的改进
以下是EJB3 JPA中的JPQL的新特性:
·简化了的查询语法
·JOIN操作
·Group By和Having Clause
·子查询
·动态查询
·指定参数(named parameter)
·批量更新和删除
此外,如果希望从特定于数据库的查询扩展中获益,则必须对查询实体使用原生(native ) SQL。
动态查询与指定查询
可以使用动态查询或指定查询(named query)。指定查询随实体存储,可从应用程序重用。
上一页 [1] [2] [3] [4] [5] [6] 下一页
 【责编:Youping】 |