"产品"我的mongodb中的集合如下所述:
{
"_id" : ObjectId("5a67755082edf74a06fc92c9"),
"productName" : "Printer",
"productId" : "5a677550d3a2246da136f294"
},
{
"_id" : ObjectId("6a67755082edf74a06fc92cd"),
"productName" : "Scanner",
"productId" : "5a688550d3a2246da136f297"
}
现在,我尝试在整个产品系列中将productId字段的值从String更新为ObjectId。因此输出应如下所示:
{
"_id" : ObjectId("5a67755082edf74a06fc92c9"),
"productName" : "Printer",
"productId" : ObjectId("5a677550d3a2246da136f294")
},
{
"_id" : ObjectId("6a67755082edf74a06fc92cd"),
"productName" : "Scanner",
"productId" : ObjectId("5a688550d3a2246da136f297")
}
我曾尝试使用以下查询
db.products.find().forEach( function(myDoc) { db.products.update("productId", {$set:{"productId": ObjectId(myDoc.productId)}})} );
但是,我正面临以下错误:
E QUERY [thread1] Error: invalid object id: length :
任何人都可以帮我解决这个问题...
答案 0 :(得分:1)
E QUERY [thread1]错误:无效的对象ID:length:
当productId
字段为null
,缺少或者不是有效的类似ObjectId的字符串(24个十六进制数字)时,会发生这种情况。