- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
HQL极为强大,但是有些人希望能够动态的使用一种面向对象API创建查询,而非在他们的Java代码中嵌入字符串。对于那部分人来说,Hibernate提供了直观的Criteria查询API,Query By Criteria简称QBC。 一个单独的查询条件是org.hibernate.criterion.Criterion接口的一个实例。Hibernate提供了一个工具类--org.hibernate.criterion.Restrictions,它定义了获得某些内置Criterion类型的工厂方法,来构造Restrictions对象,如: //添加查询条件 List persons = sess.createCriteria(Person.class) .add( Restrictions.like(name, Fritz%) ) .add( Restrictions.between(weight, minWeight, maxWeight) ) .list(); 可以使用org.hibernate.criterion.Order来为查询结果排序,而不是去拼凑order by字符串。Order类同样提供了工厂方法来构建,另一种方式是通过Property类构建,如下代码两种方式都提供了: //工厂方法来构建Order类 List persons = sess.createCriteria(Person.class) .add( Restrictions.like(name, F%) .addOrder( Order.asc(name) ) .addOrder( Order.desc(age) ) .setMaxResults(50) .list(); //Property类构建Order类 List persons = sess.createCriteria(Person.class) .add( Property.forName(name).like(F%) ) .addOrder( Property.forName(name).asc() ) .addOrder( Property.forName(age).desc() ) .setMaxResults(50) .list(); 样例查询顾名思义就是一个一个样例作为条件,把与这个样例有相同属性的实例查询出来。Hibernate提供了org.hibernate.criterion.Example类,允许用户通过一个给定实例来构建一个条件查询。如下代码,构造一个person实例作为查询条件,此时版本属性、标识符和关联被忽略。默认情况下值为null的属性将被排除。 Hibernate3提供了一个新的Criteria:DetachdCriteria。此类可脱离Session实例而存在。这样就可以将某些通用的Criteria查询条件进行抽离,每次使用前再与当前的Session绑定以获得更好的代码重用效果。 典型应用如下:DetachedCriteria类使在一个session范围之外创建一个查询,并且可以使用任意的Session来执行它。 Hibernate还支持使用SQL查询,使用SQL查询可以利用某些数据库的特性,或者用于将原有的JDBC 应用迁移到Hibernate应用上。使用命名的SQL查询还可以将SQL语句放在配置文件中配置,从而提高程序的解耦,命名SQL查询还可以用于调用存储过程。如果是一个新的应用,通常不要使用SQL查询。 SQL查询是通过SQLQuery接口来表示的,SQLQuery 接口是Query 接口的子接口,因此完全可以调用Query 接口的方法: setFirstResult(),设置返回结果集的起始点。 setMaxResults(),设置查询获取的最大记录数。 list(),返回查询到的结果集。 但SQLQuery 比Query 多了两个重载的方法: addEntity,将查询到的记录与特定的实体关联。 addScalar,将查询的记录关联成标量值。 List students = session.createSQLQuery(select * from t_student).list(); for (Iterator iter=students.iterator(); iter.hasNext();) { Object[] obj = (Object[])iter.next(); System.out.println(obj[0] + , + obj[1]); } 可以在映射文档中定义查询的名字,然后就可以象调用一个命名的HQL查询一样直接调用命名SQL查询
您可能关注的文档
最近下载
- 电力隧道电力隧道工程c标段施工方案.doc VIP
- 九年级物理第21章《信息的传递》全章课件.ppt VIP
- Unit 4 Fun with numbers(Get ready)外研版(三起)(2024)英语三年级上册.pptx VIP
- (妇产科)子宫内膜癌教学查房.pptx
- 供应商审核报告范文模板.docx VIP
- 机场行测考试题库.pdf VIP
- 2025年《网络设备配置与安全》课程标准.docx VIP
- 成都市盐道街中学高一入学语文分班考试真题含答案.docx VIP
- 成都市盐道街外国语2025高一入学英语分班考试真题含答案.docx VIP
- 成都市盐道街外国语2025高一入学数学分班考试真题含答案.docx VIP
文档评论(0)