在java条件谓词

时间:2015-07-28 05:00:14

标签: java sql oracle hibernate criteria

我有一个谓词( javax.persistence.criteria.Predicate ),它按如下方式过滤原始数据:

    public Predicate byAccountsId(Collection<Long> accountsId) {
        ParameterExpression<?> param = createParam(AOraArrayUserType.class, new AOraArrayUserType(accountsId));
        return criteriaBuilder().or(
                criteriaBuilder()
                        .equal(criteriaBuilder().function("in_ex", Long.class, actSourceJoin().get(Account_.id),
                                param), 1),
                criteriaBuilder().equal(
                        criteriaBuilder().function("in_ex", Long.class, actDestinationJoin().get(Account_.id),
                                param), 1));
    }

此谓词构建查询的下一部分:

..
where
..
act.source_id in (accountsId.values())
or act.destination_id in (accountsId.values() - array ids)
..

它工作正常,但可能有太多原始数据。我想使用&#34; Oracle功能索引&#34;,它从查询结果中删除不必要的数据。我试着按如下方式重写我的谓词:

    public Predicate byAccountsId(Collection<Long> accountsId) {
        ParameterExpression<?> param = createParam(AOraArrayUserType.class, new AOraArrayUserType(accountsId));
        return criteriaBuilder().or(
                criteriaBuilder().literal(
                        Restrictions.sqlRestriction("case when state != 'ARCHIVE' then source_id else null end"))
                        .in(param));
    }

Resurlt查询构建正常,但不返回任何结果。但是当我将结果查询复制到sql developer并运行查询时,它会返回预期的结果。

由新谓词构建的部分查询:

..
where 
..
(case when act.state != 'ARCHIVE' then act.source_id else null end) in (accountsId.values() - array ids)
..

当我使用新谓词时,有人知道为什么我没有得到正确的结果吗? 我可以将hibernate.criterion.Restrictionsjavax.persistence.criteria.Predicate一起使用吗?

1 个答案:

答案 0 :(得分:1)

您可以为您的实体(AOraArrayUserType)中的表达式定义@Formula,并使用条件中的字段

Restrictions.in("theFormulaField", param)