如何在猫鼬中插入带有collection.insert()的自定义ObjectId



我正在尝试将多个用户批量插入数据库。出于测试目的,我想为每个单独的文档设置一个特定的 ObjectId。由于某种原因,我无法插入有效的对象 ID。

例如:

    var users = [
    {
        "_id": "56955ca46063c5600627f393",
        "name": "John"
    },
    {
        "_id": "56955ca46063c5600627f392",
        "name": "Doe"
    }
];
User.collection.insert(users, function(err, docs) {
    if (err) {
        console.log("Error");
    } else {
        console.log("Succes")
    }
});

。在 mongoDB 中插入:

"_id" : "56955ca46063c5600627f393" //NOT ObjectId("56955ca46063c5600627f393")

当我尝试查询具有指定_id的文档时,这会导致各种问题。我的原始代码工作正常,但缺少漂亮的多插入选项:

var user1 = new User({
    "_id": "56955ca46063c5600627f393",
    "name": "John"
});
var user2 = new User({
    "_id": "56955ca46063c5600627f392",
    "name": "Doe"
});
user1.save(function(err, response){
    user2.save(function(err, response){
        if (err) console.log(err);
        else  console.log("ok");
        done();
    })
});

在 mongoDB 中插入:

ObjectId("56955ca46063c5600627f393")

有没有办法使用有效的 ObjectId 在数据库中插入多个文档?

根据 Mongoose 中的文档 Object 和 Mongo Shell 中的 ObjectId,您应该执行以下操作:

var ObjectId = mongoose.Types.ObjectId,
    users = [
      {
        "_id": new ObjectId("56955ca46063c5600627f393"),
        "name": "John"
      },
      {
        "_id": new ObjectId("56955ca46063c5600627f392"),
        "name": "Doe"
      }
    ];
User.collection.insert(users, function(err, docs) {
    if (err) {
        console.log("Error");
    } else {
        console.log("Succes")
    }
});

如果您使用的是MongoDB CLI,则可以使用这样的insertMany()

db.User.insertMany([
  {
    _id: ObjectId("56955ca46063c5600627f393"),
    name: "John"
  },
  {
    _id: ObjectId("56955ca46063c5600627f392"),
    name: "Doe"
  }
])

最新更新