Criteria Query 可以看作传统sql的对象化表示。

Criteria 可以由session创建。

Criteria ct= session.createCriteria(TUser.class);

先来一段小Demo:

TbItemParamExample example = new TbItemParamExample();
Criteria criteria = example.createCriteria();
criteria.andItemCatIdEqualTo(cid);

Criteria中可以增加查询条件

ct.add(Expression.eq("name","Erica"));
ct.add(Expression.eq("sex",new Integer(1)));

Criteria中增加的查询条件可以由表达式对象创建

Expression.eq(对象属性名,对象属性值);

查询条件通过Criteria的add方法加入。

表达式对象的方法有:

  • eq 等于,第一个参数是对象属性,第二个参数是值

  • allEq 参数为一个Map对象,相当于多个eq的叠加

  • gt 大于

  • ge 大于等于

  • lt <

  • le <=

  • between 在两个值之间Expression.between("age",new Integer(10),new Integer(20));

  • like like查询

  • in in查询

  • eqProperty 用于比较两个对象的属性的值是否相等

  • gtProperty

  • geProperty

  • ltProperty

  • leProperty

  • and and方法可以嵌套Expression对象,用于and关系

  • or 同上

    Expression.or(
    Expression.eq("name","hulei"),
    Expression.eq("name","jane")
    );

sql 作为Expression对象的补充,本方法提供对原生sql的支持。注意,在Hibernate3中,引入了Restrictions类作为Expression的替代,以后的版本,不再推荐使用Expression。

但是,Restrictions类的使用方法和Expression的方法一致。注意,在查询条件中,Hibernate提供了一个Example查询,当查询条件比较多的时候,可以用Example查询来简化代码,使用方法如下:

   TUser user=new TUser();
user.setLoginName("hulei");
user.setPassword("hulei");
Criteria ct=session.createCriteria(TUser.class);
ct.add(Example.create(user));
return ct.list();

复合查询

Criteria查询可以嵌套Criteria来实现复合查询

如下:

 Criteria ct=session.createCriteria(TUser.class);
Criteria ctAddress=ct.createCriteria("addresses");//这里是嵌套了一个Criteria查询,这里的addresses是TUser的属性
ctAddress.add(Expression.like("address","%shanghai%"));
List list=ct.list();

最新文章

  1. Multiple actions were found that match the request Web API
  2. 小度Wifi_设置
  3. wordpress编辑器无法切换/输入
  4. 第一篇、HTML标签
  5. phpstudy虚拟主机配置
  6. Remove Invalid Parentheses 解答
  7. ThinkPHP第十三天(CONF_PATH、APP_PATH,UEditor用法)
  8. 函数指针&amp;amp;绑定: boost::functoin/std::function/bind
  9. iOS开发那些事-iOS6苹果地图有用开发
  10. 部署 instance 到 OVS vlan100 - 每天5分钟玩转 OpenStack(138)
  11. diff命令参数
  12. K:枚举的线程安全性及其序列化问题
  13. Docker部署Elasticsearch集群
  14. Python3 ——斐波那契数列(经典)
  15. [Swift]LeetCode900. RLE 迭代器 | RLE Iterator
  16. mac openresty 源码安装 坑
  17. Python——python读取html实战,作业7(python programming)
  18. SRILM的使用及平滑方法说明
  19. C#设计模式(9)——代理模式
  20. Hive表种map字段的查询取用

热门文章

  1. 03 | 变量的解构赋值 | es6
  2. 1.在项目中使用D3.js
  3. Solon &amp; Solon Cloud 1.5.62 发布,轻量级 Java 基础开发框架
  4. 『与善仁』Appium基础 — 8、Appium自动化测试框架介绍
  5. 让textarea根据文本的长度自动调整它的高度
  6. linux安装python3.6.1
  7. [bzoj4971]记忆中的背包
  8. [atARC061F]Card Game for Three
  9. [atAGC020E]Encoding Subsets
  10. 【Spring】(1)-- 概述