我有一个像这样的 mongo 文件。
{
"_id" : ObjectId("50b429ba0e27b508d854483e"),
"array" : [
{
"id" : "1",
"letter" : "a"
},
{
"id" : "2",
"letter" : "b"
}
],
"tester" : "tom"
}
我希望能够array
使用单个 mongo 命令插入和更新,而不是在find()
then 运行中使用条件insert()
,update()
具体取决于对象的存在。
这id
是我想成为选择器的项目。所以如果我用这个更新数组:
{
"id" : "2",
"letter" : "c"
}
我必须使用$set
声明
db.soup.update({
"tester":"tom",
'array.id': '2'
}, {
$set: {
'array.$.letter': 'c'
}
})
如果我想在数组中插入一个新对象
{
"id" : "3",
"letter" : "d"
}
我必须使用$push
声明
db.soup.update({
"tester":"tom"
}, {
$push: {
'array': {
"id": "3",
"letter": "d"
}
}
})
我需要一种数组项的 upsert。
我必须以编程方式执行此操作,还是可以通过单个 mongo 调用执行此操作?