如何使用 pymongo 中对象列表中的值创建新的字段名称?
How do I create new field names using values from a list of objects in pymongo?
所以我在 mongo 数据库中有这种格式的记录(只是一个例子):
{
_id: 1,
name: "some name1",
description: "some description1",
parameters: [
{
name: "param name1",
type: "param type1",
default: "default value1"
},
{
name: "param name2",
type: "param type2",
default: "default value2"
}
]
.
.
.
}
在我的程序中,我对记录执行此聚合:
{
'$project': {
'title': '$name,
'description': True,
'parameters': {
'name': True,
'parameter_type': '$parameters.type',
'value': '$parameters.default'
}
}
}
我尝试得到的结果:
{
_id: 1,
title: 'some name1',
description: "some description1",
parameters: [
{
name: "param name1",
parameter_type: "param type1",
value: "default value1"
},
{
name: "param name2",
parameter_type: "param type2",
value: "default value2"
}
]
}
相反 我得到了:
{
_id: 1,
title: 'some name1',
description: "some description1",
parameters: [
{
name: "param name1",
parameter_type: ["param type1", "param type2"],
value: ["default value1", "default value2"]
}
]
}
我只想更改参数列表中对象的字段名称。我已经尝试查看 MongoDB 文档,但我无法找到一种方法来完成我需要的事情。
$unwind
从输入文档中解构一个数组字段并将它们按所需的投影分组。
演示 - https://mongoplayground.net/p/-pIPbSarfyx
db.collection.aggregate([
{
"$unwind": "$parameters"
},
{
"$group": {
"_id": "$_id",
"name": {
"$first": "$name"
},
"description": {
"$first": "$description"
},
"parameters": {
"$push": {
"name": "$parameters.name",
"parameter_type": "$parameters.type",
"value": "$parameters.default"
}
},
}
}
])
所以我在 mongo 数据库中有这种格式的记录(只是一个例子):
{
_id: 1,
name: "some name1",
description: "some description1",
parameters: [
{
name: "param name1",
type: "param type1",
default: "default value1"
},
{
name: "param name2",
type: "param type2",
default: "default value2"
}
]
.
.
.
}
在我的程序中,我对记录执行此聚合:
{
'$project': {
'title': '$name,
'description': True,
'parameters': {
'name': True,
'parameter_type': '$parameters.type',
'value': '$parameters.default'
}
}
}
我尝试得到的结果:
{
_id: 1,
title: 'some name1',
description: "some description1",
parameters: [
{
name: "param name1",
parameter_type: "param type1",
value: "default value1"
},
{
name: "param name2",
parameter_type: "param type2",
value: "default value2"
}
]
}
相反 我得到了:
{
_id: 1,
title: 'some name1',
description: "some description1",
parameters: [
{
name: "param name1",
parameter_type: ["param type1", "param type2"],
value: ["default value1", "default value2"]
}
]
}
我只想更改参数列表中对象的字段名称。我已经尝试查看 MongoDB 文档,但我无法找到一种方法来完成我需要的事情。
$unwind
从输入文档中解构一个数组字段并将它们按所需的投影分组。
演示 - https://mongoplayground.net/p/-pIPbSarfyx
db.collection.aggregate([
{
"$unwind": "$parameters"
},
{
"$group": {
"_id": "$_id",
"name": {
"$first": "$name"
},
"description": {
"$first": "$description"
},
"parameters": {
"$push": {
"name": "$parameters.name",
"parameter_type": "$parameters.type",
"value": "$parameters.default"
}
},
}
}
])