6.4.7:HQL查询的where子句

where子句用于筛选选中的结果,缩小选择的范围。如果没有为持久化实例命名别名,则可以直接使用属性名来引用属性:

from Person where name like 'tom%'
上面的HQL语句与下面的语句效果相同:

from Person as p where p.name like 'tom%'
复合属性表达式加强了where子句的功能,例如:

from Cat cat where cat.mate.name like "kit%"
实际上这种用法底层使用了隐式连接查询,从Hibernate3.2.3后,只有当cat.name属性引用的是普通组件属性或者单独的关联实体时才可接着在后面使用点号来引用mate的属性,如cat.mate.name;如果cat.mate是集合属性,Hibernate3.2.3以后的版本不支持这种用法。

只要没有出现集合属性,HQL语句可使用点号来隐式连接多个数据表:

from Foo foo
where foo.bar.baz.customer.address.city like "guangzhou%"
执行上面的HQL语句时会生成对应的SQL查询语句,将变成一个四表连接的查询。

特殊属性id可以用来表示一个对象的标识符:

from Cat as cat
where cat.id=123
from Cat as cat
where cat.mate.id=69




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值