Java Persistence API中带注释的命名查询可否真的非常有效?[Java编程]
本文“Java Persistence API中带注释的命名查询可否真的非常有效?[Java编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
对注释的注释
Java Persistence API (JPA) 定义了拜候数据的多种办法:通过实体管理器、通过 JPA-QL 或通过本机查询.在 JPA 中,注释用作将 Java 对象映射到底层数据库的一种机制.您还可以供应 XML 元数据作为映射注释的覆盖或备选机制.不过,我看到的大大都 JPA 利用情形都明显喜好利用注释.标准文档利用注释,而不利用基于 XML 的映射示例(仅向您显示 XML 情势)来表示全部示例这一事实大概是覆盖的缘由之一.成立对象关系映射,以便从 Java 对象模子抽象底层数据库的具体信息.不过,JPA 可以让数据库具体信息快速返回到 Java 源.在本文中,将查抄 JPA 中的各种查询款式,注释它们存在的缘由,并注释为什么对某些款式(如命名查询)举行注释没有任何意义.最后得出的结论是,这个小示例实际上是更大的问题的一部份.
利用 JPA 拜候数据
让我们快速浏览一下利用 JPA 拜候数据的各种办法,假定您非常熟习在 JPA 中映射 Java 对象的方法.
EntityManager
利用程序在运行时与 Java 对象交互.通过利用称为实体管理器的特别对象,利用程序可以查询或保持对象.EntityManager 实例与永久性上下文关联.在永久性上下文中,实体实例及其生命周期得到管理.可以认为 EntityManager 是底层永久性机制的 Facade.EntityManager 包含拜候数据的必要办法.最简单的拜候长期性数据的办法是利用 find 办法.下面是利用实体管理器通过主键查找对象的利用程序示例:
Customer customer = (Customer)em.find(Customer.class,customerId);
find 办法要求您知道主键和实际类的范例.
JPA-QL 查询
JPA 还拥有可以用于对象模子的全功效查询语言.JPA 查询语言包含很多用于更复杂查询的功效.可以通过动态方法将查询传送到实体管理器:
Query q = em.createQuery("SELECT c FROM Customer c WHERE c.name LIKE
:custName");
q.setParameter("custName", name);
q.setMaxResults(10);
List result = q.getResultList();
可以在运行时传送查询是某些动态情形(如未知条件)所必须的.不过,在大大都情形中,您但愿基于整本性能测试来锁定查询.
本机查询
JPA 还使您可以对底子表利用本机 SQL 查询,并供应映射回后果的本领:
Query q = em.createNativeQuery(
"SELECT o.id, o.quantity, o.item, i.id, i.name, i.description "+
"FROM Order o, Item i " +
"WHERE (o.quantity > 25) AND (o.item = i.id)",
"OrderItemResults");
尺度 SQL 在很多情形中都是必须的.我在从前的评论专栏中给出了很多来由.
以上是“Java Persistence API中带注释的命名查询可否真的非常有效?[Java编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |