如何将 ObjectIds 数组转换为包含原始数组元素值的字段的嵌入式文档数组?
使用 aggregate 进行此类转换。让我们创建一个带有文档的集合 −
> db.demo343.insertOne({ ... _id: 101, ... UserName: "Chris", ... details: [ ... {"Name":"John"}, ... {"Name":"David"} ... ] ... } ... ); { "acknowledged" : true, "insertedId" : 101 }
使用 find() 方法显示来自集合的所有文档 −
> db.demo343.find().pretty();
将产生以下输出 −
{ "_id" : 101, "UserName" : "Chris", "details" : [ { "Name" : "John" }, { "Name" : "David" } ] }
以下是将对象数组转换为包含原始数组元素值的字段的嵌入式文档数组的查询 −
> db.demo343.aggregate([ ... { ... $addFields: { ... details: { ... $map: { ... input: "$details", ... in: { Name: "$$this" } ... } ... } ... } ... }, ... { $out: "demo343" } ... ])
使用 find() 方法显示来自集合的所有文档 −
> db.demo343.find().pretty();
将产生以下输出 −
{ "_id" : 101, "UserName" : "Chris", "details" : [ { "Name" : { "Name" : "John" } }, { "Name" : { "Name" : "David" } } ] }
广告