1、Criteria表达式

  Criteria c=session.createCriteria(User.class);

  List result=c.list();

  Iterator it=result.iterator();

  while(it.hasNext()){

    User u=it.next();

    System.out.println("用户名:"+u.getName());

  }

   Criteria criteria = session.createCriteria(User.class);
      criteria.add(Restrictions.eq("name", "bob"));
      List result = criteria.list();
      Iterator it = result.iterator();
      while (it.hasNext()) {
          User user = (User) it.next();
          System.out.println("用户名:" + user.getName());
    }

    方法            说明

    Restrictions.eq()     对应SQL的等于(’=’)
    Restrictions.allEq()     使用Map,使用key/value进行多个相等的值的比对
    Restrictions.gt()     对应SQL的大于 (‘>’)
    Restrictions.ge()     对应SQL的大于等于 (‘>=’)
    Restrictions.lt()     对应SQL的小于 (‘<’)
    Restrictions.le()     对应SQL的小于等于 (‘<=’)
    Restrictions.between()   对应SQL的between子句
    Restrictions.like()     对应SQL的like子句
    Restrictions.in()     对应SQL的in子句
    Restrictions.and()      对应SQL的and
    Restrictions.or()     对应SQL的or
    Restrictions.not()     对应SQL的not

2、使用Example

  House house = new House();
  house.setPrice(new Double(2000));
  house.setFloorage(new Integer(40));

  Criteria criteria = session.createCriteria(House.class);
  criteria.add(Example.create(house));
  List results = criteria.list();
  Iterator it = results.iterator();
  while(it.hasNext()){
      House h= (House)it.next();
      System.out.println("标题:"+h.getTitle()+"  价格"+h.getPrice());
  }  

3、Criteria查询排序

  Criteria 查询不仅能组合出SQL中的where子句的功能,还可以组合出排序查询功能

  使用org.hibernate.criterion.Order对结果进行排序

  排序的方法为:asc() desc()

  Cirteria c=session.createCriteria(House.class);

  c.addOrder(Order.desc("price"));

  

4、Criteria查询实现分页

  Criteria的setMaxResult()方法可以限定查询返回数据的行数

  Criteria的setFirstResult()设定查询返回结果的第一行数据的位置

  Criteria c=session.createCriteria(Hose.class);

  c.setFistResult(3);

  c.setMaxResult(2);

  List result=c.list();

  Iterator it=result.iterator();

  while(it.hasNext()){

    Hose h=it.next();

    System.out.println("标题"+h.getTitle+"价格"+h.getPrice());

  }

  

Criteria查询的更多相关文章

  1. Hibernate框架之Criteria查询 和注解(重点☆☆☆☆☆,难点☆☆☆)

    写好一篇博客,不是容易的事.原因是:你要给自己以后看的时候,还能看懂,最重要的是当别人看到你的博客文章的时候,也一样很清楚的明白你自己写的东西.其实这也是一种成就感!! 对于每一个知识点,要有必要的解 ...

  2. NHibernate系列文章二十三:NHibernate查询之Criteria查询(附程序下载)

    摘要 上一篇文章介绍了NHibernate HQL,他的缺点是不能够在编译时发现问题.如果数据库表结构有改动引起了实体关系映射的类有改动,要同时修改这些HQL字符串.这篇文章介绍NHibernate面 ...

  3. Criteria查询初学者的采纳点哦

    一.Hibernate提供了5种检索对象的方式 1.导航对象图检索方式:根据已经加载的对象导航到其他对象    from  Emp e group by e.dept.deptName 2.OID检索 ...

  4. Criteria查询之sqlRestriction()的理解

    sqlRestriction()的理解 在Criteria查询中 使用sqlRestriction()方法来提供SQL语法作限定查询,作为where字句 查看官方给的例子,如下 List cats = ...

  5. Criteria查询数据

    Criteria介绍: Criteria查询是Hibernate提供的一种查询方式,与HQL基于字符串的查询形式完全不同.Hibernate提供了org.hiberanee.Criteria 接口.o ...

  6. Hibernate框架之Criteria查询

    首先给大家说说Hibernate检索方式 Hibernate提供了5种检索对象的方式 1.导航对象图检索方式:根据已经加载的对象导航到其他对象 2.OID检索方式:按照对象的OID来检索对象 3.HQ ...

  7. Hibernate 、Hql查询和Criteria查询

    HQL查询: public Object query(String name){ Session s=null; try{ s=HibernateSessionFactory.getSession() ...

  8. Hibernate框架Criteria查询

    本文章适合一些初学者 一.使用Criteria查询数据        1.条件查询            1.1:使用Criteria查询的步骤                    1.使用Sess ...

  9. 第九章 Criteria查询及注解

    第九章   Criteria查询及注解9.1 使用Criteria查询数据    9.1.1 条件查询        Criteria查询步骤:            1)使用session接口的cr ...

  10. hibernate框架学习笔记7:HQL查询、Criteria查询简介

    HQL查询:hibernate独有的查询语言 适用于不复杂的多表查询 示例: 实体类: package domain; public class Customer { private Long cus ...

随机推荐

  1. GPO配置时的注意事项

    当两个组策略冲突时: 1.如在同一层OU,后生效的组策略有效,优先级高.在组织单元的'链接的组策略对象'中标明了组策略的先后应用次序,其中下面的组策略先应用,上面的组策略后应用,即上面的组策略优先级高 ...

  2. Spring Boot实践——Mybatis分页插件PageHelper的使用

    出自:https://blog.csdn.net/csdn_huzeliang/article/details/79350425 在springboot中使用PageHelper插件有两种较为相似的方 ...

  3. ABAP-年月期间搜索帮助

    selection-screen begin of block block1 with frame title text-. parameters:p_mon1 like s031-spmon, p_ ...

  4. ABAP-动态程序生成

    科技越来越进步,人也就变的越来越懒,最终的演变就是大脑发达,四肢退化...AI的到来,准备接招吧... 报表若没有过多的用户交互逻辑,一般可通过SQ01配置生成,本文介绍用ABAP方式实现报表程序的动 ...

  5. 概率论与数理统计 Q&A:

    --------------------------------- 大数定律:大量样本数据的均值(样本值之和除以样本个数),近似于随机变量的期望(标准概率*样本次数).(样本(部分)趋近于总体)中心极 ...

  6. MVC 发布到IIS中的配置方法

    MVC 发布到IIS中的配置方法  http://msdn.microsoft.com/zh-cn/library/gg703322(v=vs.98).aspx

  7. c#数和二叉树

    树(Tree)是 n(n≥0)个相同类型的数据元素的有限集合.树中的数据元素叫结点(Node).n=0 的树称为空树(Empty Tree):对于 n>0 的任意非空树 T 有: (1)有且仅有 ...

  8. 'org.hibernate.SQLQuery' is deprecated

    'org.hibernate.SQLQuery' is deprecated 在Hibernate5.2之后,SQLQuery已经被摒弃,改用NativeQuery代替了. 在Hibernate中使用 ...

  9. sqserver2008触发器

    @参考博文 先上代码 先建个表用于测试 CREATE TRIGGER INSERT_forbidden on s after INSERT AS BEGIN RAISERROR(,) ROLLBACK ...

  10. 验证二叉查找树 · Validate Binary Search Tree

    [抄题]: [思维问题]: 不知道要定义resultType, 其实用仔细分析判断条件就行了:是否是bst+最大最小值 类似于平衡二叉树:是否平衡+左右的高度差 [一句话思路]: [输入量]:空: 正 ...