第28章 使用JPA完成查询.ppt

  1. 1、本文档共31页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
28.1 使用EntityManager根据主键查询对象 根据主键查询对象,方法的定义如下: public T T find(ClassT entityClass, Object primaryKey); 第一个参数是表示实体的类型,第二个参数表示主键值,如果要查询的实体不存在,返回null。如果没有指定有效的实体类型或者主键的类型不对,抛出异常IllegalArgumentException。 例: public Order getOrder(Long id) { return em.find(Order.class, id); } 28.2 编写简单查询 看下面的查询语句: select userinfo from Userinfo userinfo 这里使用了JPA的查询语言,简称JPA QL,其中from Userinfo指出要查询的实体,Usreinfo称为模型名,可以在声明实体类的时候通过Entity注释指定,默认情况下使用实体类的名字。select userinfo指出查询的结果,这里指出查询所有用户对象。 28.2 编写简单查询 JPA QL与SQL语句的区别: 查询的源不同:在JPA QL中,from后面的是Userinfo是要查询的实体,在标准SQL中,from后面是表名。 查询的结果不同:在JPA QL中,select后面的userinfo表示查询Userinfo对象,实际上是from Userinfo userinfo中的userinfo,在标准SQL中,select后面是表中的列。 28.2 编写简单查询 简单实例 例1:查询所有订单。 select order from Order order 例2:查询所有顾客。 select customer from Customer customer 例3:查询名字为Java的图书。 select book from Book book where book.bookname=’Java’ 例4:查询所有用户的名字。 select customer.customer_name from Customer customer 例5:查询所有客户的编号和名字 select customer.customer_name,customer.customer_id from Customer customer 28.3 创建Query对象 使用Query对象执行JPA QL语句; 通过EntityManager来创建Query对象; public Query createQuery(String qlString); 方法的参数是要执行的查询语句,返回值是Query对象。得到Query对象之后可以从中获取查询结果。 例1:查询所有订单: Query query = em.createQuery(“select order from Order order”); 例2:查询所有顾客: Query query = em.createQuery(“select customer from Customer customer”); 28.4 使用命名查询 可以把查询语句集中管理,然后给他起名字,需要的时候根据名字访问,称为命名查询。 先定义命名查询; 然后调用createNamedQuery生成Query对象 28.4.1 定义命名查询 命名查询在实体类上定义,可以通过NamedQueries来定义多个命名查询,每个命名查询使用一个NamedQuery来定义。NamedQuery包括两部分,使用name指出查询的名字,通过query指出查询语句。下面的例子是Userinfo实体类中定义的多个命名查询。 例: @NamedQueries( { @NamedQuery(name = Userinfo.findByUserid, query = SELECT u FROM Userinfo u WHERE u.userid = :userid), … }) public class Userinfo{ … } 查询语句中使用了:userid等,表示变量。 28.4.2 调用createNamedQuery生成Query对象 使用createNamedQuery方法创建Query对象 public Query createNamedQuery(String name); 例: Query q = em.createNamedQuery(Userinfo.findByUserid); 28.5 处理查询中的变量 位置参数(使用?n) public Query setParameter(int position,Ob

文档评论(0)

kehan123 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档