- 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
- 中国国家标准 GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- 《GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计》.pdf
- 中国国家标准 GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- 《GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置》.pdf
- 中国国家标准 GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- GB/T 17889.4-2024梯子 第4部分:铰链梯.pdf
- 《GB/T 17889.4-2024梯子 第4部分:铰链梯》.pdf
文档评论(0)