2

在混合 AND 和 OR 谓词时,我正在尝试为微风.js 配置正确的语法。我在微风网站上没有看到一个例子,在其他任何地方都找不到。

基本上我想在我的 WHERE 子句中做这样的事情:

(
age > 30  AND
sex == 'M' AND
jobStartDate >= '1/1/2000'
)

OR

(
exemptStatus == 1
)

这将带回符合 3 个标准或豁免的实体。我正在使用带有 ODATA 语法的 EF6。

谢谢

4

1 回答 1

7

尝试这个:

    var Predicate = breeze.Predicate;
    var baseQuery = EntityQuery.from("Something");
    var pred1 = new Predicate("age", ">", 30);
    var pred2 = new Predicate("sex", "==", 'M');
    var pred3 = new Predicate("jobStartDate", ">=", new Date(2000,1,1));
    var pred4 = new Predicate("exemptStatus", "==", 1);
    var compositePred = pred1.and(pred2).and(pred3).or(pred4);
    var query = baseQuery.where(compositePredicate);
    myEntityManager.executeQuery(query);

或者

    var compositePred = Predicate.and(pred1, pred2, pred3).or(pred4);
于 2014-03-07T01:39:12.900 回答