gpt4 book ai didi

MongoDB - 仅检索匹配的子文档和根文档

转载 作者:可可西里 更新时间:2023-11-01 09:56:31 25 4
gpt4 key购买 nike

编辑:问题已解决,见下文。

我有以下文件:

db.clients.insert({
_id: ObjectId("524d720d8d3ea014a52e95bb"),
company: "Example",
logins: [
{
"name": "John Smith",
"username": "test",
"password": "eF9wnBEys0OzL5vmR/OHGCaekHiw/Miy+XvbDdayxeo=",
"email": "a@a.com",
"last": null,
"roles": ["CONFIG"]
},
{
"name": "Guest",
"username": "guest",
"password": "K/gYODb7XPo0erySvL276DyPi4+stPPK4jM3pJ8aaVg=",
"email": "a@a.com",
"last": null,
"roles": []
}
]
});

现在,我想使用此文档对我的客户进行身份验证。但是,我不想检索每个子登录,我只想要匹配的那个。

这就是我使用聚合的原因:

db.clients.aggregate(
{
"$project": {
"login": "$logins",
"_id": 0
}
},
{
"$unwind": "$login"
},
{
"$group": {
"_id": "$login.username",
"login": {
"$first": "$login"
}
}
},
{
"$match": {
"login.username": "test",
"login.password": "eF9wnBEys0OzL5vmR/OHGCaekHiw/Miy+XvbDdayxeo=",
}
}
);

哪个工作正常,给了我:

{
"result" : [
{
"_id" : "test",
"login" : {
"name" : "John Smith",
"username" : "test",
"password" : "eF9wnBEys0OzL5vmR/OHGCaekHiw/Miy+XvbDdayxeo=",
"email" : "a@a.com",
"last" : null,
"roles" : [
"CONFIG"
]
}
}
],
"ok" : 1
}

但是现在,棘手的部分是我还想检索根文档字段。例如_idcompany

但是无论我怎么努力,我都做不到。你有解决方案吗? :)


编辑:

好吧,其实也没那么难。对不起!

db.clients.aggregate(
{
"$project": {
"login": "$logins",
"_id": "$_id",
"company": "$company"
}
},
{
"$unwind": "$login"
},
{
"$group": {
"_id": "$login.username",
"login": {
"$first": "$login"
},
"clientId": {
"$first": "$_id"
},
"company": {
"$first": "$company"
},
}
},
{
"$match": {
"login.username": "test",
"login.password": "eF9wnBEys0OzL5vmR/OHGCaekHiw/Miy+XvbDdayxeo=",
}
}
);

最佳答案

您可以使用 find$ 来做到这一点位置投影算子:

db.clients.find({
"logins.username": "test",
"logins.password": "eF9wnBEys0OzL5vmR/OHGCaekHiw/Miy+XvbDdayxeo=",
}, {
"logins.$": 1,
"company": 1
})

投影中的 $ 包含查询中匹配的 logins 数组元素的索引。

输出:

{
"_id": ObjectId("524d720d8d3ea014a52e95bb"),
"company": "Example",
"logins": [
{
"name": "John Smith",
"username": "test",
"password": "eF9wnBEys0OzL5vmR/OHGCaekHiw/Miy+XvbDdayxeo=",
"email": "a@a.com",
"last": null,
"roles": [
"CONFIG"
]
}
]
}

关于MongoDB - 仅检索匹配的子文档和根文档,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19178867/

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