- 1、本文档共31页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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
您可能关注的文档
- 第23课 美术的辉煌复习课件.ppt
- 第23课 世界经济的区域集团化.ppt
- 第23课新中国初期的外交 2.ppt
- 第23课新中国初期的外交.ppt
- 第23章 破坏社会主义市场经济秩序罪之(三).ppt
- 第24课 世界经济的全球化趋势 学案(人教版必修2).doc
- 第24课欧洲经济一体化的进程.doc
- 第25章 头部及其器官检查.ppt
- 第25章之三、诈骗罪.ppt
- 第26章《二次函数》单元测试题1.doc
- Haier海尔413升风冷变频多门冰箱 BCD-413WGHFD1BSJU1(白)说明书用户手册.pdf
- Siemens西门子工业抽屉式断路器主回路后垂直连接 抽屉式断路器主回路后垂直连接使用手册.pdf
- Samsung三星智能佩戴设备 Galaxy Fit3安全手册.pdf
- Samsung三星滚筒洗衣机 AI神 黑钻热泵洗烘旗舰 WD18DB8995BZSC使用手册.pdf
- Sakura樱花消毒柜 保洁柜消毒柜 SCQ-130D6用户手册说明书.pdf
- Hifiman头领科技ARYA UNVEILED说明书用户手册.pdf
- Siemens西门子工业抽屉式主回路连接前置端子 支撑件 抽屉式主回路连接前置端子 支撑件使用手册.pdf
- Siemens西门子工业中性线的外部电流传感器 中性线的外部电流传感器使用手册.pdf
- Siemens西门子工业电子脱扣单元 电子脱扣单元使用手册.pdf
- Razer雷蛇Playstation 专用雷蛇战锤狂鲨极速版 RZ12-038203 用户指南 (简体中文)说明书用户手册.pdf
最近下载
- 腰椎的解剖及腰部的层次解剖ppt参考课件.ppt
- 知识产权助推新质生产力发展.pptx VIP
- NB∕T 10805-2021 水电工程溃坝洪水与非恒定流计算规范.pdf
- 2022年鄄城县工会系统招聘考试题库及答案解析.docx VIP
- 2024年医师定期考核必考题库及答案.pdf
- 2023年互联网信息审核员理论考试题库(含答案).pdf VIP
- 2024中考语文《西游记》历年真题专练(学生版+解析版).pdf VIP
- 高中音乐鉴赏测试题.doc VIP
- 人教三上数学《数学广角—集合》单元作业设计方案(13页).pdf VIP
- 省级政府和重点城市一体化政务服务能力调查评估报告2021年.pdf VIP
文档评论(0)