gpt4 book ai didi

hibernate - 具有null属性的Hibernate OR条件

转载 作者:行者123 更新时间:2023-12-02 14:50:31 25 4
gpt4 key购买 nike

我为我的Grails域对象之一提供了一个筛选器页面,该页面具有一个用于搜索多个域字段的筛选器字段。我在一个like(..)子句中有多个or过滤器,以便在对象的任何字段匹配时列出该对象。主对象上的一个字段是另一个域对象,因此条件代码如下所示:

    or{
like("field1", "%" + params.generalFilterValue + "%")
like("field2", "%" + params.generalFilterValue + "%")
like("field3", "%" + params.generalFilterValue + "%")
otherDomainObject{
like("field4", "%" + params.generalFilterValue + "%")
}

}

但是,当“otherDomainObject”为null时,即使其他字段之一匹配,也不会列出该对象。

有没有办法解决?

最佳答案

条件中的关联始终是内部联接,因此如果关联为null,则将结果集丢弃。相反,您可以使用 LEFT_JOIN

import static org.hibernate.criterion.CriteriaSpecification.LEFT_JOIN

...
or {
like("field1", "%" + params.generalFilterValue + "%")
like("field2", "%" + params.generalFilterValue + "%")
like("field3", "%" + params.generalFilterValue + "%")

otherDomainObject( LEFT_JOIN ) {
like("field4", "%" + params.generalFilterValue + "%")
}
}

关于hibernate - 具有null属性的Hibernate OR条件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32128897/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com