MongoDBは、前に要素に応じて要素を削除します(反復)
Aug 19 2020
同じオブジェクトに同様の要素がある場合、条件付きのMongoDBオブジェクトから($ unset)要素を削除したいと思います。私のオブジェクト:
{
"_id": "5eabf8b144345b36b00bfbaa",
"ranktime": [{
"pos":"2",
"datum":"Mon May 05 2020 12:22:52 GMT+0200 (GMT+02:00)",
"source":"SOURCE2"
},{
"pos":"1",
"datum":"Fri May 01 2020 12:23:10 GMT+0200 (GMT+02:00)",
"source":"SOURCE1"
},{
"pos":"37",
"datum":"Fri May 01 2020 12:25:14 GMT+0200 (GMT+02:00)",
"source":"SOURCE2"
},{
"pos":"12",
"datum":"Fri May 01 2020 12:25:14 GMT+0200 (GMT+02:00)",
"source":"SOURCE2"
},{
"pos":"37",
"datum":"Fri May 01 2020 18:45:27 GMT+0200 (GMT+02:00)",
"source":"SOURCE2"
}]
}
したがって、日付が前のオブジェクトと同じであるranktime
場合は、エントリを削除したいと思いranktime.source == "SOURCE2"
ます。実際、私はの単一の要素を反復処理する必要がありranktime
ます。これはMongoDBで可能ですか?
期待される結果は次のとおりです。
{
"_id": "5eabf8b144345b36b00bfbaa",
"ranktime": [{
"pos":"2",
"datum":"Mon May 05 2020 12:22:52 GMT+0200 (GMT+02:00)",
"source":"SOURCE2"
},{
"pos":"1",
"datum":"Fri May 01 2020 12:23:10 GMT+0200 (GMT+02:00)",
"source":"SOURCE1"
},{
"pos":"37",
"datum":"Fri May 01 2020 12:25:14 GMT+0200 (GMT+02:00)",
"source":"SOURCE2"
}]
}
回答
1 mickl Aug 19 2020 at 08:38
基本的には使用することができます$削減配列を処理し、使用前の要素を定義するために$ましょうと$ arrayElemAt文を。新しい$ set構文を使用すると、updateステートメント内で集計を使用できます。
db.col.updateMany({}, [
{
$set: { ranktime: { $reduce: {
input: "$ranktime", initialValue: [], in: { $let: {
vars: { last: { $arrayElemAt: [ "$$value", -1 ] } },
in: {
$cond: [ { $and: [
{ "$eq": [ "$$last.source", "SOURCE2" ] },
{ "$eq": [ { $substr: [ "$$last.datum", 0, 15 ] }, { $substr: [ "$$this.datum", 0, 15 ] } ] }, ] }, "$$value",
{ $concatArrays: [ "$$value", [ "$$this" ] ] }
]
}
}
}
}
}
}
}
])
集計例