我可以在mongodb查询中使用OR和AND的组合吗?
下面的代码不按预期工作
db.things.find({
$and:[
{$or:[
{"first_name" : "john"},
{"last_name" : "john"}
]},
{"phone": "12345678"}
]});
数据库内容:
> db.things.find();
{ "_id" : ObjectId("4fe8734ac27bc8be56947d60"), "first_name" : "john", "last_name" : "hersh", "phone" : "2222" }
{ "_id" : ObjectId("4fe8736dc27bc8be56947d61"), "first_name" : "john", "last_name" : "hersh", "phone" : "12345678" }
{ "_id" : ObjectId("4fe8737ec27bc8be56947d62"), "first_name" : "elton", "last_name" : "john", "phone" : "12345678" }
{ "_id" : ObjectId("4fe8738ac27bc8be56947d63"), "first_name" : "eltonush", "last_name" : "john", "phone" : "5555" }
当查询上面的查询时-我什么也没有得到!
> db.things.find({$and:[{$or:[{"first_name" : "john"}, {"last_name" : "john"}]},{"phone": "12345678"}]});
>
我用的是mongo1.8.3
5条答案
按热度按时间qcuzuvrc1#
AND接受2个表达式的数组OR,phone。
OR接受2个表达式first_name,last_name的数组。
和
*或
注意:如果这不起作用,请升级到最新版本的MongoDB。
sulc1iza2#
使用隐式AND运算的缩写:
zpgglvta3#
这可以通过以下方式实现(mongodb3.4)
这是一个很好的例子
https://docs.mongodb.com/manual/reference/operator/query/and/#and-queries-with-multiple-expressions-specifying-the-same-operator
此查询将选择所有文档,其中:
价格字段值等于0.99或1.99,销售字段值等于真或数量字段值小于20。
下面是$和条件与$或查询的示例,即匹配任何条件,例如
考虑以下查询...
此查询将选择所有文档,其中:
位置数组在588054 c63879 f2 e767 a1 d553和is_ryward = 1和points_reqiured_to_redeem_reward〈500
或者
位置数组在588054 c63879 f2 e767 a1 d553和is_freebie
7z5jn7bk4#
我相信只有MongoDB v2.0+支持$和。我很惊讶控制台首先接受了表达式。我将尝试在我拥有的1.8服务器上重新创建。
还可以查看
$and
的10 Gen高级查询文档。我将您的示例数据输入到v1.8x和v2.0x MongoDB服务器中。查询在v2.0x上工作,在v1.8x上失败。这证实了我(和Miikka)的怀疑,即问题出在
$and
和您的服务器版本上。我在Web here上找到了一个(可以说)聪明的变通方法。我希望这能有所帮助。
-SethO
8aqjt8rx5#
你可以这样写你的查询: