Mongo查询语法错误

时间:2016-08-29 15:49:08

标签: regex mongodb

我不明白为什么其中一种语法起作用而另一种语法不起作用。我的理解是他们两者的意思相同。

此作品

{ 'profile.fname' : { $regex:  ".*" + this.queryParams.value + ".*", $options: '-i'}},

这不起作用

{ profile : { fname : { $regex:  ".*" + this.queryParams.value + ".*", $options: '-i'}}},

示例数据结构如下所示:

{
"_id":"ybhng3YCu4W4MSzz9",
"createdAt":"2016-08-23T10:44:33.088Z",
"emails":[{"address":"xy@z.co.uk","verified":false}],
"profile":
{
"fname":"name",
"lname":"otherName"
},
"roles":["admin"]
}

第一个产生正确的结果,但第二个产生任何东西 - 就像在一个空数组中一样。从调试我知道这在某个地方必须是错误的语法,但我看不到它。

我使用meteor作为服务器端。

1 个答案:

答案 0 :(得分:0)

如果您要查询嵌入式文档,则需要像在第一次查询中一样使用点符号。

如果您提供文件,则必须完全匹配。在这种情况下,你真的需要:

{ profile: { fname: "name", lname :"otherName"} }

当然这对我来说看起来很糟糕;为什么首先将配置文件作为嵌入式文档?而不是像这样的东西:

{
"_id":"ybhng3YCu4W4MSzz9",
"createdAt":"2016-08-23T10:44:33.088Z",
"emails":[{"address":"xy@z.co.uk","verified":false}],

"fname":"name",
"lname":"otherName"

"roles":["admin"]
}

参考: Query on Embedded Documents