Hibernate Criteria查询详解:对象化查询与操作

需积分: 3 1 下载量 77 浏览量 更新于2024-07-13 收藏 3.76MB PPT 举报
"这篇文档主要介绍了在Hibernate框架中如何使用Criteria查询进行数据操作,Criteria查询是一种以对象方式构建查询的方法,它可以提供更加灵活且面向对象的查询体验。此外,文档也简要提到了HQL(Hibernate Query Language)的使用方法作为对比。" 在Hibernate中,Criteria查询提供了一种更加面向对象的方式来执行数据库查询。以下是一些关于Criteria查询的关键知识点: 1. 创建Criteria对象:首先,你需要通过Session接口的createCriteria()方法来创建一个Criteria对象,它代表了你想要查询的实体类。 2. 模糊查询:你可以使用Restrictions类的like方法实现模糊查询,例如,`criteria.add(Restrictions.like("property", "%value%"))`,其中"property"是你查询的属性,"%value%"是匹配的值。 3. 大于等于和小于等于:Criteria查询支持使用ComparisonOperator类的ge和le方法,如`criteria.add(Restrictions.ge("property", value))`和`criteria.add(Restrictions.le("property", value))`,分别代表大于等于和小于等于。 4. 支持in和between:你可以使用Restrictions的in方法处理包含多个值的条件,如`criteria.add(Restrictions.in("property", valuesArray))`。对于"between"操作,可以使用`criteria.add(Restrictions.between("property", minValue, maxValue))`。 5. 数组类型:Criteria查询允许你处理数组类型的属性,可以使用Restrictions的in方法配合数组来实现。 6. 属性浏览语法:Criteria查询支持类似于EL表达式的属性浏览,使得查询更加简洁,如`criteria.createAlias("relatedEntity", "alias")`,将关联实体映射为别名。 7. 排序规则:通过调用Criteria的addOrder方法,可以添加多个排序规则,例如`criteria.addOrder(Order.asc("propertyName"))`或`criteria.addOrder(Order.desc("propertyName"))`,分别表示升序和降序排序。 相对于HQL(Hibernate Query Language),Criteria查询提供了更动态的查询构造方式,可以在运行时根据需要构建查询条件,而HQL则更接近SQL语句,但它是面向对象的,处理对象和实体之间的关系。HQL的使用步骤通常包括获取Session、编写HQL语句、创建Query对象以及执行查询。 在HQL中,`from`关键字后面跟的是实体类名而非数据库表名,可以省略`select`子句,系统默认选择所有字段。同时,可以使用别名来简化查询,如`from TblFwxx as fw`。HQL中的错误通常涉及到类名的大小写、对象查询语言与表名的混淆以及关键词的大小写问题。 属性查询在HQL中可以通过指定属性名称来实现,例如`select date, title from TblFwxx`,这样只会返回指定属性的值,而不是整个对象的信息。 Hibernate的Criteria查询和HQL都是强大的查询工具,可以根据实际需求和项目结构选择适合的查询方式。它们都极大地简化了Java应用程序与数据库之间的交互,并提高了代码的可读性和可维护性。