Hibernate Criteria查询教程:条件组合查询和排序

需积分: 9 5 下载量 141 浏览量 更新于2024-07-13 收藏 323KB PPT 举报
"条件或方式组合查询条件-T21.9_Criteria查询java经典教程经典教材" 本篇教程主要讲解了如何使用Criteria API在Java中进行组合查询,结合Hibernate框架,通过实例代码演示如何使用Criteria对象进行条件查询,并对查询结果进行排序。 一、Criteria查询简介 Criteria查询是Hibernate框架中的一种查询方式,通过使用Criteria对象可以进行复杂的查询操作。Criteria查询可以与HQL(Hibernate Query Language)查询相比,Criteria查询更灵活、更强大。 二、创建Criteria对象 要使用Criteria查询,首先需要创建一个Criteria对象,使用SessionFactory的getCurrentSession()方法获取当前Session对象,然后使用Session的createCriteria()方法创建Criteria对象。例如: ```java Session session = HibernateSessionFactory.getSessionFactory().getCurrentSession(); Criteria criteria = session.createCriteria(Person.class); ``` 三、添加查询条件 使用Criteria对象可以添加多个查询条件,使用Restrictions类中的方法可以创建各种查询条件,例如: ```java Criterion criterion = Restrictions.or(Restrictions.like("name", "wu%"), Restrictions.eq("deptno", 1100)); criteria.add(criterion); ``` 上述代码使用了or()方法将两个查询条件组合起来,第一个条件是name字段以"wu"开头,第二个条件是deptno字段等于1100。 四、排序查询结果 使用Criteria对象可以对查询结果进行排序,使用Order类中的方法可以创建排序对象,例如: ```java criteria.addOrder(Order.desc("id")); ``` 上述代码使用了desc()方法将查询结果按照id字段降序排序。 五、执行查询 使用Criteria对象可以执行查询,使用list()方法可以获取查询结果,例如: ```java List<Person> lstPerson = criteria.list(); ``` 六、事务提交 使用Hibernate框架需要提交事务,以确保数据的完整性,例如: ```java session.beginTransaction().commit(); ``` 七、Criteria查询的核心方法 Criteria查询的核心方法包括: * add():添加查询条件 * addOrder():添加排序对象 * list():执行查询 * setMaxResults():设置查询结果的最大数量 * setFirstResult():设置查询结果的起始索引 八、Criteria查询的优点 Criteria查询的优点包括: * 灵活性强:Criteria查询可以进行复杂的查询操作 * 高效性:Criteria查询可以使用索引和缓存,提高查询效率 * 灵活的排序:Criteria查询可以对查询结果进行灵活的排序 九、总结 本篇教程主要讲解了如何使用Criteria API在Java中进行组合查询,通过实例代码演示了如何使用Criteria对象进行条件查询,并对查询结果进行排序。 Criteria查询是一种强大的查询方式,能够满足复杂的查询需求。