- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第28章 使用JPA完成查询
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
您可能关注的文档
- 电器控制与可编程控制器2.ppt
- 电商家装培训.ppt
- 电子邮件营销的作业.ppt
- 电子编辑.ppt
- 电工仪表使用.ppt
- 电容的识别(说课PPT).ppt
- 电工学 课件 实验二 叠加定律和基尔霍夫定律验证.ppt
- 电气图示.ppt
- 电源电动势_闭合电路欧姆定律教科版.ppt
- 电类第12章.ppt
- 陕西金融资产管理股份有限公司招聘笔试题库精选答案详解.docx
- 陕西高速延长石油有限公司招聘笔试题库及答案详解(名校卷).docx
- 2022年江苏银宝控股集团有限公司校园招聘考试试题及答案详解(全国通用).docx
- 2023年山东济南市章丘区殡仪馆工作人员招聘10人笔试模拟试题及答案详解(典优).docx
- 2023年国企招聘衢州市慧城产业发展集团有限公司招聘考试真题附答案详解(研优卷).docx
- 陕西延长石油(集团)炼化公司招聘笔试题库附答案详解(培优b卷).docx
- 2022年无锡市江阴文化商业旅游产业集团有限公司招聘笔试真题附答案详解(夺分金卷).docx
- XXX镇XXXX年学习教育自查评估报告.docx
- 2025年上海市安全员C3证(专职安全员-综合类)考试题库.docx
- 建设项目监理公司绩效考核细则.docx
最近下载
- 新《保险法》知识考试题库资料100题(含答案).pdf VIP
- 人教版二年级上册数学全册教学设计(配2025年秋新版教材).docx
- 管廊工程监理监理大纲(2017.2.13).doc VIP
- 2024年7月1日实施新版医疗器械采购、收货、验收、贮存、销售、出库、运输和售后服务工作程序.docx
- 蓝铜胜肽的合成方法.pdf VIP
- 美术课堂开学第一课 (1).pptx VIP
- 卡尔加里精神分裂症抑郁量表.pdf VIP
- 规则引擎项目开发手册及规范指导ilog篇.doc VIP
- 幼儿园 小班家长会课件.ppt VIP
- 人教版2024八年级上册英语 Unit 1 Happy Holiday 第1课时 教案(表格式).docx VIP
文档评论(0)