gpt4 book ai didi

regex - Mongo查询语法错误

转载 作者:可可西里 更新时间:2023-11-01 10:51:51 26 4
gpt4 key购买 nike

我不明白为什么其中一种语法有效而另一种无效。据我了解,它们的意思几乎相同。

这行得通

{ '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 作为服务器端。

最佳答案

如果您要针对嵌入式文档进行查询,则需要像在第一个查询中那样使用点表示法。

如果您向其提供文档,则它必须完全匹配。在这种情况下,您确实需要:

{ 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

关于regex - Mongo查询语法错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39210275/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com