




已阅读5页,还剩1页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Hibernate QBC查询 QBC查询: QBC查询就是通过使用Hibernate提供的Query By Criteria API来查询对象,这种API封装了SQL语句的动态拼装,对查询提供了更加面向对象的功能接口。我们看下面的示例程序: Criteria criteria=session.createCriteria(User.class); criteria.add(Expression.eq(“name”,”zx”); criteria.add(Expression.eq(“age”,new Integer(27); List list=criteria.list(); 当执行criteria.list()时会生成类似这样的SQL语句:Select * from user where name=zx and age=27;所以在这里我们可以看出,Criteria实际上是一个查询容器,它对查询条件表达式的添加进行了封装,具体的查询条件是通过add()方法添加的,而且具体的查询条件的表达式运算是通过Expression指定的。Hibernate在运行期会根据Criteria指定的表达式条件来添加查询条件,并且生成查询语句。这种方式非常符合Java以及所有面向对象编程语言的编程方式,所以大多数的持久层框架都提供了对这种方式查询的支持。下面我们讲解这种查询方式的各个技术细节。 1、Criteria查询表达式: 正如我们所见,Expression对查询语句的表达式进行了封装和限制,下表列出了Expression所有的方法,以及每个方法所对应的查询表达式及其限制。 方法描述 Expression.eq对应SQL的“field=value”表达式 如:Expression.eq(“name”,”zx”); Expression.allEq方法的参数为一个Map类型对象,包含多个名/值对对应关系,相当于多个Expression.eq的叠加 Expression.gt对应SQL的“fieldvalue”表达式 Expression.ge对应SQL的“field=value”表达式 Expression.lt对应SQL的“field”表达式 Expression.le对应SQL的“fieldfield”SQL表达式 Expression.geProperty用于比较两个属性值,对应”field=field”SQL表达式 Expression.ltProperty用于比较两个属性值,对应”field表达式 Expression.leProperty用于比较两个属性值,对应”field(select avg(age) from user group by age); Restrictions类的常用方法 Restrictions.eq(String propertyName,Object value) 等于 Restrictions.allEq(Map propertyNameValues) 使用Map key/value进行多个等于的比对 Restrictions.gt(String propertyName, Object value) 大于 (gt-greater than) Restrictions.ge(String propertyName, Object value) 大于等于 = (ge-greater equal) Restrictions.It(String propertyName, Object value) 小于less than) Restrictions.Le(String propertyName, Object value) 小于等于less equal) Restrictions.between(String propertyName, Object lo, Object hi) 对应SQL语句的Between子句 Restrictions.like(String propertyName, Object value) 对应SQL语句的LIKE子句 Restrictions.in(String propertyName, Collection value) 对应SQL语句的in子句 Restrictions.and(Criterion lhs, Criterion rhs) And关系 Restrictions.or(Criterion lhs, Criterion rhs) Or关系 Restrictions.sqlRestriction(String sql,Object values,Type types) SQL限定查询 工具类Order提供设置排序方式 Order.asc(String propertyName) 升序排序 Order.desc(String propertyName) 降序排序 工具类Projections提供对查询结果进行统计与分组操作 Porjections.avg(String propertyName) 求某属性的平均值 Projections.count(String propertyName) 统计某属性的数量 Projections.countDistinct(String propertyName) 统计某属性的不同值的数量 Projections.groupProperty(String propertyName) 指定一组属性值 Projections.max(String propertyName) 某属性的最大值 Projections.min(String propertyName) 某属性的最小值 PjectionList() 创建一个新的projectionList对象 Projections.rowCount() 查询结果集中记录的条数 Projections.sum(String propertyName) 返回某属性值的合计 List cats = session.createCriteria(Cat.class) .createAlias(kittens, kt) .createAlias(mate, mt) .add( Rest
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 国家事业单位招聘2025中国人民大学国际关系学院招聘1人笔试历年参考题库附带答案详解
- 哈尔滨市2025黑龙江省气象部门高校毕业生招聘19人(第五批次)笔试历年参考题库附带答案详解
- 2025海南琼海市旅游健康文化发展有限公司招聘10人笔试参考题库附带答案详解
- 2025浙江丽水市青田县县属国有企业青田经济开发区投资发展有限公司招聘丙类人员6人笔试参考题库附带答案详解
- 2025年黄山市徽州国有投资集团有限公司招聘13人笔试参考题库附带答案详解
- 2025年福建省福州左海控股集团有限公司招聘2人笔试参考题库附带答案详解
- 2025年安徽省生态环境产业集团有限公司招聘10人笔试参考题库附带答案详解
- 2025年内蒙古鄂尔多斯市天安公交集团招聘21人笔试参考题库附带答案详解
- 2025年上半年贵州毕节市纳雍县鸽子花农业有限公司招聘10人笔试参考题库附带答案详解
- 2025山东菏泽市劳信就业服务有限公司招聘派遣制人员24人笔试参考题库附带答案详解
- 财政分局合同管理制度
- 破产清算律师管理制度
- 口腔诊室6S管理
- oem生产订单管理制度
- 中华骄傲主题班会课件
- 财务共享:理论与实务(第2版·立体化数字教材版)讲义 11第十一章 资产管理模块
- 野生动植物保护与利用
- 踝关节骨折的护理查房
- 大数据的国内外研究现状及发展动态分析
- 医院定向委托培养合同10篇
- 青梅种植管理技术
评论
0/150
提交评论