gpt4 book ai didi

javascript - MongoDB 无法更新文档,因为 _id 是字符串,而不是 ObjectId

转载 作者:IT老高 更新时间:2023-10-28 13:20:38 26 4
gpt4 key购买 nike

我正在做一个 rest api 来在 mongo 数据库和 web 应用程序之间交换数据。这些数据是 json 格式的。

我在更新文档时遇到了麻烦:

cannot change _id of a document.

事实上,在我的 JSON 中,文档的 _id 存储为字符串并反序列化为字符串。而它在 mongo 中存储为 ObjectID。这解释了为什么 mongo 会引发错误。

  • 在 mongo 中:_id: ObjectId('51051fd25b442a5849000001')
  • 在 JSON 中:_id:"51051fd25b442a5849000001"

为避免这种情况,我手动将 _id 属性从 string 转换为 ObjectID。但它看起来很难看,并且会与其他 BSON 类型一起失败。

问:有没有一种简洁的方法可以避免这种情况或进行良好的 JSON/BSON 转换?

下面是我用来更新文档的代码。我将 nodejs 与 express 和 mongodb 与 native 驱动程序一起使用。

exports.updateById = function(req, res) {
var id = req.params.id;
var map = req.body;

map._id = new ObjectID.createFromHexString( map._id); // Manual conversion. How to avoid this???

console.log( 'Updating map: ' + id);
console.log( 'Map: ' + JSON.stringify( map));

db.collection('maps', function(err, collection) {
if(err) throw err;
collection.update(
{'_id': new BSON.ObjectID(id)}, map, {safe:true},
function(err, result) {
if (err) {
console.log('Updating map err: ' + JSON.stringify( err));
res.json( 500, {'message':'An error has occurred while updating the map', 'error': err});
} else {
console.log('Updating succeed');
res.send(map);
}
}
);
});

};

最佳答案

由于您无法修改 _id 字段,因此更好的方法是简单地从 map 对象中删除该字段,而不是将其转换为 ObjectId。

所以这个:

delete map._id;

而不是这个:

map._id = new ObjectID.createFromHexString( map._id);

如果您想返回更新后的对象,就像您尝试使用 res.send(map); 一样,您应该使用 findAndModify而不是 update 这样您就可以访问生成的文档,而不仅仅是发布的内容。

关于javascript - MongoDB 无法更新文档,因为 _id 是字符串,而不是 ObjectId,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14585507/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com