我有一些问题,当我尝试upsert我的对象与新的(解析从xml文件),但我得到了以下错误:
MongoError: exception: After applying the update to the document {_id: ObjectId('55be3c8f79bae4f80c6b17f8') , ...}, the (immutable) field '_id' was found to have been altered to _id: ObjectId('55be5f15ae
5597401724aab3')
下面是我的代码:
xmlFile.product_list.product.forEach(function (product) {
var productEntity = new Product({
product_id: parseInt(product.id),
parent_id: parseInt(product.parent_id),
sku: product.sku,
title: product.title,
pricenormal: parseFloat(product.price_normal),
pricewholesale: parseFloat(product.price_wholesale),
pricewholesalelarge: parseFloat(product.price_wholesale_large),
pricesale: parseFloat(product.price_sale),
weight: parseFloat(product.weight),
volume: parseFloat(product.volume),
unittype: product.unit_type,
status: product.status,
datecreating: product.datecreating,
sp: product.sp,
guaranteeext: product.guarantee_ext,
used: product.used,
statusfull: product.status_full,
description: null,
url: null
});
items.push(productEntity);
});
items.forEach(function (product) { //update or create new products
Product.findOneAndUpdate({product_id: product.product_id}, product, {upsert: true}, function (err) {
if (err) return updateDBCallback(err);
updateDBCallback(null, 'saved');
});
});
我试着用这样的暗示:
//product._id = mongoose.Types.ObjectId(); //doesn't work
//delete product._id // doesn't delete _id from product
但是没有用。所以我不想更新我的product._id,我只想更新其他字段。
5条答案
按热度按时间mhd8tkvw1#
当你执行
new Product()
时,会生成一个新的_id
,沿着其他东西。q0qdq0h22#
您可以使用以下命令:
px9o7tmv3#
尝试使用
xqnpmsa84#
当我检查
_id
是String
而不是ObjectId
时,我得到了这个错误(在Java驱动程序中)。正确 Package 查询:
rxztt3cl5#
C #/. NET语言
如果您使用_user. ReplaceOneAsync(user =〉user. Id == id,userIn)来更新集合中的现有记录,那么请确保包含正在更新的实际记录的id,将其留空意味着您希望它在创建类的新示例时为您生成newGuid。