在云代码中,我使用这种代码进行了查询:

theMainQuery = new Parse.Query("myClass");
theMainQuery.equalTo("fieldOne", "champion");

theSubQuery = new Parse.Query("myClass");
theSubQuery.equalTo("fieldTwo", "USA");

the2ndSubQuery = new Parse.Query("myClass");
the2ndSubQuery.equalTo("fieldTwo", "BRASIL");

theSubQuery = Parse.Query.or(theSubQuery,the2ndSubQuery);

theMainQuery = Parse.Query.and(theMainQuery,theSubQuery);


换句话说,我想要基于此条件的查询:

((fieldOne equals "champion") and ((fieldTwo equals "USA") or (fieldTwo equals "BRASIL")))


在通常的C风格编写中,我想选择匹配的记录:

((fieldOne == "champion") && ((fieldTwo == "USA") || (fieldTwo == "BRASIL")))


问题是它不起作用,我想我的Parse.Query.and是错误的。那我怎样才能得到想要的结果呢?

当然,我很乐意避免以这种长格式重新编写查询:

 (((fieldOne == "champion") && (fieldTwo == "USA")) || ((fieldOne == "champion") && (fieldTwo == "BRASIL")))

最佳答案

好的,您可以在一个Query对象中完成操作。

我感觉到您要寻找的是'containedIn'...因此,您指定键'fieldTwo'并将值的数组传递给'or'。

因此,这就是我认为的样子,我在Objective-C中实现了此功能,但没有使用javascript实现。但是这是我的JavaScript版本

var query = new Parse.Query('myclass');
query.equalTo('fieldOne', 'champion');
query.containedIn('fieldTwo', ['USA', 'Brazil']);
query.find();


我希望这就是您要寻找的...顺便说一句,我能够在文档https://parse.com/docs/js_guide#queries中找到它。那里的文档非常有帮助,但有时对我没有帮助:P

10-02 06:28
查看更多