17-Hibernate查询.pptVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
17-Hibernate查询

Hibernate查询 - 课后作业 完成用户表与角色表之间的联合查询 Hibernate查询 本次课目标: HQL查询语言 Criteria标准查询 本地SQL查询 Hibernate查询 数据查询与检索是Hibernate中的一个亮点。 Hibernate语言查询(Hibernate Query Language,HQL),完全面向对象的查询语句。Hibernate官方推荐使用HQL进行查询。 标准化对象查询(Criteria Query):以对象的方式进行查询,将查询语句封装为对象操作。符合Java 程序员的编码习惯,但不够成熟。 Native SQL Queries(原生SQL查询):直接使用标准SQL语言或跟特定数据库相关的SQL进行查询。 Hibernate提供的检索对象的方式 导航对象图检索方式 根据已经加载的对象,导航到其他对象。例如,对于已经加载的Customer对象,调用它的getOrders().iterator()方法就可以导航到所有关联的Order对象。 OID检索方式 按照对象的OID来检索对象。Session的get()和load()方法提供了这种功能。要求事先知道了OID。 HQL检索方式 使用面向对象的HQL查询语言。Session的find()方法用于执行HQL查询语句。此外,Hibernate还提供了Query接口,它是Hibernate提供的专门的HQL查询接口,能够执行各种复杂的HQL查询语句。 QBC检索方式 使用QBC(Query By Criteria)API来检索对象。这种API封装了基于字符串形式的查询语句,提供了更加面向对象的接口。 本地SQL检索方式 使用本地数据库的SQL查询语句。Hibernate会负责把检索到的JDBC ResultSet结果集映射为持久化对象图。 HQL检索方式 HQL(Hibernate Query Language)是面向对象的查询语言,和SQL查询语言相似。HQL是使用最广的一种检索方式。它具有以下功能: 在查询语句中设定各种查询条件 支持投影查询,即仅检索出对象的部分属性 支持分页查询 支持连接查询 支持分组查询,允许使用having和group by关键字 提供内置聚集函数,如sum()、min()和max() 能够调用用户定义的SQL函数 支持子查询,即嵌入式查询 支持动态绑定参数 一些简单的例子 from User user where user.age=20; from User user where user.age between 20 and 30; from User user where user.age in(20,30); from User user where user.name is null; from User user where user.name like ‘%zx%’; from User user where (user.age%2)=1; from User user where user.age=20 and user.name like ‘%zx%’; update User user set user.age=20 where user.age=18; delete from User user where user.age=18; 1 ) 检索一个属性 List list=session.createQuery(“select user.name from User user ”).list(); for(int i=0;ilist.size();i++){ ?System.out.println(list.get(i));} 2 ) 检索多个属性: List list=session.createQuery(“select user.name,user.age from User user ”).list(); for(int i=0;ilist.size();i++){ ?Object[] obj=(Object[])list.get(i); ?System.out.println(obj[0]); ?System.out.println(obj[1]);} 3 )动态构造实例 List list=session.createQuery(“select new User(user.name,user.age) from User user ”).list(); for(int i=0;ilist.size();i++){ ?User user=(User)list.get(i); ?System.out.println(user.getName()); ?S

文档评论(0)

xcs88858 + 关注
实名认证
文档贡献者

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

版权声明书
用户编号:8130065136000003

1亿VIP精品文档

相关文档