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