我正在使用Parse Dashboard来管理我的iOS应用程序的用户。此外,我正在使用使用MongoDB数据库的外部API。
我目前面临的问题是,从Parse Dashboard创建的用户具有较小的ID,而不是MongoDB的ObjectID,而其他未被解析的资源则由普通的ObjectID生成。
例如。 用户对象:
{
_id:"qVnyrGynJE",
user_name:"Aditya Raval"
}
文档对象:
{
_id:"507f191e810c19729de860ea",
doc_name:"Marksheet",
user:"qVnyrGynJE"
}
任务对象:
{
_id:"507f191e810c19729de860ea",
task_name:"Marksheet",
user:"qVnyrGynJE"
}
我也将Keystone.js用作后端管理仪表盘,所以基本上由于KeyStone.js内部这种混合的ID关系而被破坏,Keystone.js崩溃了。
因此,我想通过修复Keystone.js将所有现有的小ID迁移到普通的MongoDB ObjectID,而又不打乱关系或任何其他演练
最佳答案
您可以运行以下内容:
var users = db.Users.find({});
for(var i = 0; i < users.length(); i++)
{
var oldId = users[i]._id;
delete users[i]._id;
db.Users.insert(users[i], function(err, newUser) {
db.Documents.updateMany({"user": oldId},{ $set: { "user": newUser._id }});
//Do this for all collections that need to be update.
});
);
}
db.Users.deleteMany({_id: { $type: "string" }});