使用mongodb和mongoose,我无法获得$ push将元素追加到我的数组中。在我运行之后,我检查了mongo shell并且新的追加不在那里。不确定我做错了什么:
UserModel.findOne({ firstName: "bob" }, 'pets', function(err, user) {
UserModel.update(user, {
$push: {
pets: {
name: "pear", type: "pig"
}
}
}, function(err, numAffected, raw) {
if (err) console.log(err);
console.log('updated ' + JSON.stringify(numAffected));
});
});
Mongoose: users.ensureIndex({ username: 1 }) { unique: true, background: true }
Mongoose: users.findOne({ firstName: 'bob' }) { fields: { pets: 1 } }
Mongoose: users.update({ pets: [ { type: 'dog', name: 'apple' }, { type: 'cat', name: 'felix' } ], _id: ObjectId("56a53d45a428cbde3c4299f8") }) { '$push': { pets: { name: 'pear', type: 'pig' } } } {}
updated {"ok":1,"nModified":0,"n":0}
> bob = db.users.find()[0]
{
"_id" : ObjectId("56a53d45a428cbde3c4299f8"),
"firstName" : "bob",
"lastName" : "smith",
"username" : "bob123",
"pets" : [
{
"name" : "apple",
"type" : "dog"
},
{
"name" : "felix",
"type" : "cat"
}
],
"__v" : 0
}
>
更新:
更改类型字段后,仍然没有成功。这次我只想推动{ $push: { pets: "sssss" } }
。
UserModel.findOne({ firstName: "bob" }, 'pets', function(err, user) {
UserModel.update(user,
{ $push: { pets: "sssss" }},
function(err, numAffected, raw) {
if (err) console.log(err);
console.log('updated ' + JSON.stringify(numAffected));
});
});
这是实际的mongodb日志:
2016-01-29T03:14:37.030+0000 I COMMAND [conn17] command curves.$cmd command: update { update: "users", updates: [ { q: { pets: [ { petType: "pig", name: "pear" } ], _id: ObjectId('56aad0a3ef5848c231ec80ed') }, u: { $push: { pets: "sssss" } }, upsert: false, multi: false } ], ordered: true, writeConcern: { w: 1 } } ntoskip:0 keyUpdates:0 writeConflicts:0 numYields:0 reslen:55 locks:{ Global: { acquireCount: { r: 1, w: 1 } }, Database: { acquireCount: { w: 1 } }, Collection: { acquireCount: { w: 1 } } } protocol:op_query 0ms
答案 0 :(得分:3)
下面。这是类似的代码,它正在工作。 findbyidandupdate
需要添加" new:true" 可选参数。否则你将把旧文档归还给你。
var express = require("express");
var app = express();
var mongoose = require("mongoose");
mongoose.connect("mongodb://localhost/population");
var db = mongoose.connection;
db.on("error", console.error.bind(console, "connection error:"));
db.once("open", function(){
var mongoose = require("mongoose");
var userSchema = new mongoose.Schema({
firstname : String,
lastname : String,
pets : []
})
var userModel = mongoose.model("User", userSchema);
var bob = new userModel({
"firstname" :"bob",
"lastname" : "Smith",
"pets" : [
{name : "apple", type : "dog"},
{name : "felix", type : "cat"}
]
})
bob.save(bob, function(err, user){
console.log(user)
});
userModel.findOneAndUpdate(
{firstname : "bob"},
{$push : {"pets" : {name : "pear", type : "pig"}}},
//THE MOST IMPORTANT PART ADD new : true
{safe : true, upsert : true, new : true},
function(err, model){
console.log(model);
}
)
})//once
app.listen(3000, function(){
console.log("listening on port: " , 3000)
})
答案 1 :(得分:2)
真正的原因是type
数组中使用的pets
不正确。实际上,type
是mongoose
的一个关键字,用于标记Schema Type
。
如果将type
更改为type1
,请执行以下架构
var UserSchema = new mongoose.Schema({
// ....
pets: [{name: String, type1: String}],
});
保存的pets
应该与额外的_id
"pets" : [
{
"name" : "o3",
"type1" : "t3",
"_id" : ObjectId("56a5df9adea3071b0de83407")
},
在这种情况下,我们可以执行以下操作
UserModel.findOne({ firstName: "bob" }, 'pets', function(err, user) {
UserModel.update(user, {
$push: {
pets: {
name: "pear", type1: "pig"
}
}
}, function(err, numAffected, raw) {
结果是
"pets" : [
{
"name" : "o3",
"type1" : "t3",
"_id" : ObjectId("56a5df9adea3071b0de83407")
},
{
"type1" : "pig",
"name" : "pear",
"_id" : ObjectId("56a5dff3a648301d0db118df")
}
],