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

相关文章

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

C语言逗号运算符和逗号表达式的使用小结

《C语言逗号运算符和逗号表达式的使用小结》本文详细介绍了C语言中的逗号运算符和逗号表达式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习... 在C语言中逗号“,”也是一种运算符,称为逗号运算符。 其功能是把两个表达式连接其一般形式为:表达

MyBatis-Plus使用动态表名分表查询的实现

《MyBatis-Plus使用动态表名分表查询的实现》本文主要介绍了MyBatis-Plus使用动态表名分表查询,主要是动态修改表名的几种常见场景,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录1. 引入依赖2. myBATis-plus配置3. TenantContext 类:租户上下文

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

MySQL 数据库进阶之SQL 数据操作与子查询操作大全

《MySQL数据库进阶之SQL数据操作与子查询操作大全》本文详细介绍了SQL中的子查询、数据添加(INSERT)、数据修改(UPDATE)和数据删除(DELETE、TRUNCATE、DROP)操作... 目录一、子查询:嵌套在查询中的查询1.1 子查询的基本语法1.2 子查询的实战示例二、数据添加:INSE

springboot+mybatis一对多查询+懒加载实例

《springboot+mybatis一对多查询+懒加载实例》文章介绍了如何在SpringBoot和MyBatis中实现一对多查询的懒加载,通过配置MyBatis的`fetchType`属性,可以全局... 目录springboot+myBATis一对多查询+懒加载parent相关代码child 相关代码懒

在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)

《在DataGrip中操作MySQL完整流程步骤(从登录到数据查询)》DataGrip是JetBrains公司出品的一款现代化数据库管理工具,支持多种数据库系统,包括MySQL,:本文主要介绍在D... 目录前言一、登录 mysql 服务器1.1 打开 DataGrip 并添加数据源1.2 配置 MySQL

Go语言中如何进行数据库查询操作

《Go语言中如何进行数据库查询操作》在Go语言中,与数据库交互通常通过使用数据库驱动来实现,Go语言支持多种数据库,如MySQL、PostgreSQL、SQLite等,每种数据库都有其对应的官方或第三... 查询函数QueryRow和Query详细对比特性QueryRowQuery返回值数量1个:*sql

Python中的sort方法、sorted函数与lambda表达式及用法详解

《Python中的sort方法、sorted函数与lambda表达式及用法详解》文章对比了Python中list.sort()与sorted()函数的区别,指出sort()原地排序返回None,sor... 目录1. sort()方法1.1 sort()方法1.2 基本语法和参数A. reverse参数B.

MyBatis Plus大数据量查询慢原因分析及解决

《MyBatisPlus大数据量查询慢原因分析及解决》大数据量查询慢常因全表扫描、分页不当、索引缺失、内存占用高及ORM开销,优化措施包括分页查询、流式读取、SQL优化、批处理、多数据源、结果集二次... 目录大数据量查询慢的常见原因优化方案高级方案配置调优监控与诊断总结大数据量查询慢的常见原因MyBAT