13

3 つの条件を指定する Hibernate 基準制限を作成する必要があります。問題は、最後の条件が実際には AND 演算子を使用した条件であることです。

私の最初の条件:

Criterion startInRange = Restrictions.between("expectedStartCanonicDate", 
                                               rangeStart, rangeEnd);

私の2番目の条件:

Criterion endInRange = Restrictions.between("expectedCompletionCanonicDate", 
                                             rangeStart, rangeEnd);

MY 3 番目の条件は、次の 2 つの条件を一緒に AND する必要があります。

criteria.add(Restrictions.le("expectedStartCanonicDate", rangeStart));
criteria.add(Restrictions.ge("expectedCompletionCanonicDate", rangeEnd));

やりたい制限は、条件1または条件2または条件3です。私を近づける例を見つけました。orLogicalExpression を使用して、または最初の 2 つの条件を一緒に使用することはできますが、特に最後の条件が実際には 2 つの別個の条件 ' ' を一緒にする場合に、3つの条件を使用する方法がわかりませんanded

何かご意見は?フレッド

4

2 に答える 2

47

にリンクされた一連の制限orは、論理和と呼ばれます。にリンクされた一連の制限andは、接続詞と呼ばれます。

だから、あなたが必要なのは

  • 3番目の条件の1つの接続詞
  • 1番目、2番目、および3番目の条件をリンクする1つの論理和:

だからここに行く:

Criterion startInRange = Restrictions.between("expectedStartCanonicDate", rangeStart, rangeEnd);

Criterion endInRange = Restrictions.between("expectedCompletionCanonicDate", rangeStart, rangeEnd);

Criterion thirdCondition = 
    Restrictions.conjunction().add(Restrictions.le("expectedStartCanonicDate", rangeStart))
                              .add(Restrictions.ge("expectedCompletionCanonicDate", rangeEnd));

Criterion completeCondition = 
    Restrictions.disjunction().add(startInRange)
                              .add(endInRange)
                              .add(thirdCondition);

criteria.add(completeCondition);
于 2011-11-19T13:36:16.353 に答える
1
Criteria criteriaObj = sessionselectreply.createCriteria(TaskReplyVO.class,"taskreply")
                .createAlias("taskreply.objTaskView", "taskview")
                .createAlias("objMailTo", "mailto")
                .add(Restrictions.eq("taskview.longTaskId", taskid))
                .add(Restrictions.eq("mailto.longuserid", userid));
于 2014-04-25T09:05:36.097 に答える