使用 mongoimport 时,你能指定 _id 应该是 UUID 吗?

问题描述

我正在使用 mongoimport 将大量 CSV 记录导入到 MongoDb。目前,认情况下,_id 字段被设置为 ObjectId,如下所示:

"_id" : ObjectId("5fea8abcda05f098a1ac9857") 

是否有一个参数可以传递给 mongoimport 命令,它会导致 MongoDb 在导入时为每个文档生成一个新的 UUID,例如:

"_id" : UUID("0ef6bc1d-017d-4c85-9393-2d7832598d03")

否则,如果无法在导入时为 _id 字段分配 UUID,是否可以编写另一个查询来对导入的集合执行此更新?

解决方法

这似乎无法在导入时切换到 uuid,但您可以这样做:

mongoimport --db <your_db> --collection tmpCol --drop --type csv --file data.csv --headerline

然后:

db.tmpCol.find().forEach(function (document) {
  document._id = UUID()
  db.desiredCollection.insert(document)
})

可能相关:https://forums.meteor.com/t/how-to-mongoimport-and-not-use-objectid-in-the--id-fields/23963/2