- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Java-EE轻量级框架应用开发第7章-Hibernate查询 本章要点 Hibernate的检索方式 HQL检索方式 条件查询〔Criteria Queries〕 SQL检索方式 检索方式的介绍 OID检索方式〔Object Identity〕 按照对象的OID来检索对象。Session的get()和load()方法提供了这种功能。如果在应用程序中事先知道了OID,就可以使用这种检索对象的方式 HQL检索方式(Hibernate Query Language) 使用面向对象的HQL查询语言来检索对象。Session的find()方法用于执行HQL查询语句 Hibernate还提供了Query接口,它是Hibernate提供的专门的HQL查询接口,能够执行各种复杂的HQL查询语句 QBC检索方式〔Query By Criteria〕 使用QBC API来检索对象。这种API封装了基于字符串形式的查询语句,提供了更加面向对象的接口,对特定的持久层对象进行查询,利于扩展 本地SQL检索方式 使用本地数据库的SQL查询语句。Hibernate会负责把检索到的JDBC ResultSet结果集映射为持久化对象图 检索方式的比较 在实际使用中,一种检索并无根本的优劣,而是要看不同的情况,结合各种查询的优点和缺点,考虑采用哪种检索会更加简单和适宜一点 HQL功能最强大,适合各种情况,但是动态条件查询构造起来很不方便 Criteria最适合动态条件查询,不太适合统计查询,QBE还不够强大,只适合相当简单的查询 本地SQL可以实现特定数据库的SQL,但是可移植性就牺牲了 针对Web应用来说,大局部常规查询都是动态条件查询,所以首选使用Criteria,并且Hibernate3提供了DetachedCriteria,可以在web层构造好DetachedCriteria再进入Session执行查询,非常方便实用 涉及到统计查询和非常复杂的关联查询,Criteria就无能为力了,这种情况下选择使用HQL 如果必须使用某些数据库的特性,那么选择使用本地SQL Hibernate的检索方式 HQL检索方式 条件查询〔Criteria Queries〕 SQL检索方式 HQL简介 HQL是面向对象的查询语言, 它和 SQL 查询语言有些相似 HQL 是非常有意识的被设计为完全面向对象的查询,它可以理解如继承、多态和关联之类的概念 HQL除了 Java 类与属性的名称外,查询语句对大小写并不敏感 HQL关键字将使用小写字母,使用完全大写的关键字会使查询语句的可读性更强,但当把查询语句嵌入到Java语句中的时候使用大写关键字比较难看 功能 在查询语句中设定各种查询条件 支持投影查询, 即仅检索出对象的局部属性 支持分页查询 支持连接查询 支持分组查询, 允许使用 HAVING 和 GROUP BY 关键字 提供内置聚集函数, 如sum(), min() 和max() 能够调用 用户定义的SQL函数或标准的SQL函数 支持子查询 支持动态绑定参数 HQL查询的步骤 获取Hibernate Session对象 编写HQL语句 以HQL为参数,调用Session的createQuery创立查询对象〔如果HQL语句有参数,调用Query的set方法赋值〕 调用Query对象的list等方法返回实例 使用HQL查询数据 from子句 返回entity.Customer类的所有实例 为了在查询的其他局部里引用 Customer,需要分配一个别名,关键字 as 是可选的 通常不需要使用类的完整命名 ,因为autoimport〔自动引入〕是缺省的情况 查询语句中别名的开头局部小写被认为是实践中的好习惯,这样做与 Java 变量的命名标准保持了一致 from Customer from Customer as customer from entity.Customer Customer数据表,使用HQL查询所有的数据 Session session = sessionFactory.openSession(); Transaction transaction = session.beginTransaction(); Query query = session.createQuery(from Customer); ListCustomer list = query.list(); for (Customer c:list) { } transaction mit(); session.close(); select 子句 选择将哪些对象与属性返回到查询结果集中 查询语句可以返回值为任何类型的属性 查询语句可以返回多个对象和〔或〕属性,存放
原创力文档


文档评论(0)