Criteria 查询表达式

2024-02-21 20:48
文章标签 查询 表达式 criteria

本文主要是介绍Criteria 查询表达式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Criteria 本身只是一个查询容器,具体的查询条件需要通过 Criteria.add

方法添加到 Criteria 实例中。

如前例所示, Expression 对象具体描述了查询条件。针对 SQL 语法,

Expression 提供了对应的查询限定机制,包括:

方法

描述

Expression.eq

 

对应 SQL field = value ”表达式。

Expression.eq( "name" , "Erica" )

Expression.allEq

 

参数为一个 Map 对象,其中包含了多个属性-值对

应关系。相当于多个 Expression.eq 关系的叠加。

 

Expression.gt

 

对应 SQL 中的 “field > value ” 表达式

 

Expression.ge

 

对应 SQL 中的 “field >= value” 表达式

 

Expression.lt

 

对应 SQL 中的 “field < value” 表达式

 

Expression.le

 

对应 SQL 中的 “field <= value” 表达式

 

Expression.between

 

对应 SQL 中的 “between” 表达式

如下面的表达式表示年龄( age )位于 13 50

间内。

Expression.between( "age" , new

Integer(13), new Integer(50));

 

Expression.like

 

对应 SQL 中的 “field like value” 表达式

 

Expression.in

 

对应 SQL 中的 ”field in …” 表达式

 

Expression.eqProperty

 

用于比较两个属性之间的值,对应 SQL 中的“ field

= field ”。

如:

Expression.eqProperty(

"TUser.groupID" ,

"TGroup.id"

);

 

Expression.gtProperty

 

用于比较两个属性之间的值,对应 SQL 中的“ field

> field

 

Expression.geProperty

 

用于比较两个属性之间的值,对应 SQL 中的“ field

>= field

 

Expression.ltProperty

 

用于比较两个属性之间的值,对应 SQL 中的“ field

< field

 

Expression.leProperty

 

用于比较两个属性之间的值,对应 SQL 中的“ field

<= field

 

Expression.and

 

and 关系组合。

如:

Expression.and(

Expression.eq( "name" , "Erica" ),

Expression.eq(

"sex" ,

new Integer(1)

)

);

 

Expression.or

 

or 关系组合。

如:

Expression.or(

Expression.eq( "name" , "Erica" ),

Expression.eq( "name" , "Emma" )

);

 

Expression.sql

 

作为补充,本方法提供了原生 SQL 语法的支持。我

们可以通过这个方法直接通过 SQL 语句限定查询

条件。

下面的代码返回所有名称以“ Erica ”起始的记录:

Expression.sql(

lower({alias}.name) like lower(?) ,

"Erica%" ,

Hibernate.STRING

);

其中的“ {alias} ”将由 Hibernate 在运行期使

用当前关联的 POJO 别名替换。

 

 

注意 Expression 各方法中的属性名参数(如 Express.eq 中的第一个参数),这里所谓属性名是 POJO 中对应实际库表字段的属性名(大小写敏感),而非库表中的实际字段名称。

 

Criteria 高级特性

限定返回的记录范围

通过 criteria. setFirstResult/setMaxResults 方法可以限制一次查询返回

的记录范围 :

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

// 限定查询返回检索结果中,从第一百条结果开始的 20 条记录

criteria.setFirstResult(100);

criteria.setMaxResults(20);

对查询结果进行排序

// 查询所有 groupId=2 的记录

// 并分别按照姓名 ( 顺序 ) groupId (逆序)排序

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

criteria.add(Expression.eq( "groupId" , new Integer(2)));

criteria.addOrder(Order.asc( "name" ));

criteria.addOrder(Order.desc( "groupId" ));

Criteria 作为一种对象化的查询封装模式,不过由于 Hibernate 在实现过程中将精力

更加集中在 HQL 查询语言上,因此 Criteria 的功能实现还没做到尽善尽美(这点上, OJB

Criteria 实现倒是值得借鉴),因此,在实际开发中,建议还是采用 Hibernate

方推荐的查询封装模式: HQL

 

 

这篇关于Criteria 查询表达式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/733029

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

数据库oracle用户密码过期查询及解决方案

《数据库oracle用户密码过期查询及解决方案》:本文主要介绍如何处理ORACLE数据库用户密码过期和修改密码期限的问题,包括创建用户、赋予权限、修改密码、解锁用户和设置密码期限,文中通过代码介绍... 目录前言一、创建用户、赋予权限、修改密码、解锁用户和设置期限二、查询用户密码期限和过期后的修改1.查询用

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

使用C#代码计算数学表达式实例

《使用C#代码计算数学表达式实例》这段文字主要讲述了如何使用C#语言来计算数学表达式,该程序通过使用Dictionary保存变量,定义了运算符优先级,并实现了EvaluateExpression方法来... 目录C#代码计算数学表达式该方法很长,因此我将分段描述下面的代码片段显示了下一步以下代码显示该方法如

MySQL不使用子查询的原因及优化案例

《MySQL不使用子查询的原因及优化案例》对于mysql,不推荐使用子查询,效率太差,执行子查询时,MYSQL需要创建临时表,查询完毕后再删除这些临时表,所以,子查询的速度会受到一定的影响,本文给大家... 目录不推荐使用子查询和JOIN的原因解决方案优化案例案例1:查询所有有库存的商品信息案例2:使用EX

SpringBoot基于MyBatis-Plus实现Lambda Query查询的示例代码

《SpringBoot基于MyBatis-Plus实现LambdaQuery查询的示例代码》MyBatis-Plus是MyBatis的增强工具,简化了数据库操作,并提高了开发效率,它提供了多种查询方... 目录引言基础环境配置依赖配置(Maven)application.yml 配置表结构设计demo_st

Redis KEYS查询大批量数据替代方案

《RedisKEYS查询大批量数据替代方案》在使用Redis时,KEYS命令虽然简单直接,但其全表扫描的特性在处理大规模数据时会导致性能问题,甚至可能阻塞Redis服务,本文将介绍SCAN命令、有序... 目录前言KEYS命令问题背景替代方案1.使用 SCAN 命令2. 使用有序集合(Sorted Set)

MyBatis框架实现一个简单的数据查询操作

《MyBatis框架实现一个简单的数据查询操作》本文介绍了MyBatis框架下进行数据查询操作的详细步骤,括创建实体类、编写SQL标签、配置Mapper、开启驼峰命名映射以及执行SQL语句等,感兴趣的... 基于在前面几章我们已经学习了对MyBATis进行环境配置,并利用SqlSessionFactory核

PostgreSQL如何查询表结构和索引信息

《PostgreSQL如何查询表结构和索引信息》文章介绍了在PostgreSQL中查询表结构和索引信息的几种方法,包括使用`d`元命令、系统数据字典查询以及使用可视化工具DBeaver... 目录前言使用\d元命令查看表字段信息和索引信息通过系统数据字典查询表结构通过系统数据字典查询索引信息查询所有的表名可

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去