当前位置:七道奇文章资讯编程技术Java编程
日期:2011-03-22 16:13:00  来源:本站整理

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编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:

  • 利用Javascript实现网页水印(非图片水印)
  • Java开辟环境的搭建
  • Ubuntu java安装与配置
  • 办理Ubuntu 10.04 Firefox3.6 Java浏览器插件不工作的问
  • Ubuntu重装后Java环境的设置
  • Sun Java进入Ubuntu 10.10软件中央
  • Ubuntu 10.10配置Java开辟环境
  • 在Ubuntu 10.10中配置Java环境变量的办法
  • Ubuntu下Java环境的搭建
  • Ubuntu 10.04 下安装 Java, JRE
  • Ubuntu 10.04下的搭建SUN JAVA开辟环境
  • Ubuntu 12.04安装java7
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .