如何在mongodb的整个集合中将特定字段从String转换为ObjectId?

时间:2018-01-30 17:10:17

标签: mongodb

"产品"我的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 :

任何人都可以帮我解决这个问题...

1 个答案:

答案 0 :(得分:1)

  

E QUERY [thread1]错误:无效的对象ID:length:

productId字段为null,缺少或者不是有效的类似ObjectId的字符串(24个十六进制数字)时,会发生这种情况。