【发布时间】:2012-05-04 12:02:18
【问题描述】:
我在 MongoDB 中有一个文档集合,其中一个属性存储为字符串,如果将其保存为 BSON::ObjectId 会更好。
集合名称为foo,字段名为bar。让每个字段 bar 将其现有值转换为 BSON::ObjectId 实例的最佳方法是什么?
【问题讨论】:
-
是否有其他字段引用它?
-
没有其他字段引用它
我在 MongoDB 中有一个文档集合,其中一个属性存储为字符串,如果将其保存为 BSON::ObjectId 会更好。
集合名称为foo,字段名为bar。让每个字段 bar 将其现有值转换为 BSON::ObjectId 实例的最佳方法是什么?
【问题讨论】:
我认为您不能更改对象 ID,但您可以执行以下操作:
db.whatevers.find().forEach(function(x) {
x.oldId = x._id; // this can be handy :)
x._id = new ObjectID();
db.whatevers.insert(x);
})
db.whatevers.remove({oldId:{$exists:false}}};
【讨论】:
这是你的意思吗? (你有一个 ObjectId 的十六进制字符串,你想把它变成一个 ObjectId)
> db.foo.insert({bar:new ObjectId().str});
> db.foo.insert({bar:new ObjectId().str});
> db.foo.insert({bar:new ObjectId().str});
> db.foo.find();
{ "_id" : ObjectId("4f95e00d9060633ce7fbab94"), "bar" : "4f95e00d9060633ce7fbab93" }
{ "_id" : ObjectId("4f95e0119060633ce7fbab96"), "bar" : "4f95e0119060633ce7fbab95" }
{ "_id" : ObjectId("4f95e0119060633ce7fbab98"), "bar" : "4f95e0119060633ce7fbab97" }
> db.foo.find().forEach(function(doc) { db.foo.update({_id:doc._id},{$set:{bar:new ObjectId(doc.bar)}}); });
> db.foo.find();
{ "_id" : ObjectId("4f95e00d9060633ce7fbab94"), "bar" : ObjectId("4f95e00d9060633ce7fbab93") }
{ "_id" : ObjectId("4f95e0119060633ce7fbab96"), "bar" : ObjectId("4f95e0119060633ce7fbab95") }
{ "_id" : ObjectId("4f95e0119060633ce7fbab98"), "bar" : ObjectId("4f95e0119060633ce7fbab97") }
或者这就是你的意思? (你有一个字符串,但你想把它吹走并在它的位置创建一个新的 ObjectId)
> db.foo.insert({bar:"some string id"});
> db.foo.insert({bar:"some string id2"});
> db.foo.insert({bar:"some string id3"});
> db.foo.find();
{ "_id" : ObjectId("4f95e1779060633ce7fbaba5"), "bar" : "some string id" }
{ "_id" : ObjectId("4f95e1799060633ce7fbaba6"), "bar" : "some string id2" }
{ "_id" : ObjectId("4f95e17b9060633ce7fbaba7"), "bar" : "some string id3" }
> db.foo.find().forEach(function(doc) { db.foo.update({_id:doc._id},{$set:{bar:new ObjectId()}}); });
> db.foo.find();
{ "_id" : ObjectId("4f95e1779060633ce7fbaba5"), "bar" : ObjectId("4f95e1819060633ce7fbaba8") }
{ "_id" : ObjectId("4f95e1799060633ce7fbaba6"), "bar" : ObjectId("4f95e1819060633ce7fbaba9") }
{ "_id" : ObjectId("4f95e17b9060633ce7fbaba7"), "bar" : ObjectId("4f95e1819060633ce7fbabaa") }
【讨论】:
db.foo.find().forEach(function(doc) { db.foo.update({_id:doc._id},{$set:{bar:new ObjectId(doc.bar)}}); });