【发布时间】:2017-03-16 03:15:53
【问题描述】:
我刚刚开始学习 mongodb 并开始为自己的业务开发个人应用程序。
我将在这里解释我的问题,因为我自己无法解决,我尝试了很多方法。
我这样创建一个对象:
db.morosos.insert({
"idlor": "XXXXX",
"comunidad": "XXXXX",
"vivienda": "XXXXX",
"demandado": "XXXXX",
"importe": "XXXXX",
"datos": [
{
"fecha": "XXXXXX",
"dato": "XXXXXX"
}],
"date": new Date("<dd-mm-YYYY>")})
然后我想用新的“fecha”和新的“dato”像数组一样添加新的“datos”。
我尝试使用:
db.morosos.updateOne(
{ "idlor" : "XXXXX" },
{ $inc: { "datos" : { "fecha": "XXXXX", "dato": "XXXX" } } } )
db.morosos.updateOne(
{ "idlor" : "XXX" },
{ $push: { "datos" : { "fecha": "XXXXX",
"dato": "XXXX" } } } )
db.morosos.update(
{ "idlor" : "XXXX" },
{
$addToSet: {
"datos": {
"fecha": "XXXXX",
"dato": "XXXXX"
}
}
} )
没有人能像我想要的那样工作,它只会改变信息或让我失败,比如:
WriteResult({
"nMatched" : 0,
"nUpserted" : 0,
"nModified" : 0,
"writeError" : {
"code" : 16837,
"errmsg" : "Cannot apply $addToSet to a non-array field. Field named 'datos' has a non-array type Object in the document _id: ObjectId('58c81ba0fb02f3066e2af169')"
}})
WriteResult({
"nMatched" : 0,
"nUpserted" : 0,
"nModified" : 0,
"writeError" : {
"code" : 16837,
"errmsg" : "The field 'datos' must be an array but is of type Object in document {_id: ObjectId('58c81ba0fb02f3066e2af169')}"
}})
所以目前我不知道该怎么办,我还在寻找如何解决它。
谢谢。
【问题讨论】:
标签: mongodb