Hibernate数据库查询

本文介绍如何在不使用Hibernate自动生成的DAO的情况下,手动调用CriteriaQuery进行灵活的数据查询。文章详细解释了多种查询表达式的使用方法,包括等值、范围、区间等条件的设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

若不使用Hibernate自动生成的DAO,可以手动调用Criteria Query。使用方法如下:(参考:http://jingyan.baidu.com/article/0964eca233d7cf8284f53656.html,Expression没用过,用Restritions)

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.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");


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值