我有一个像这样的 Mongo 收藏
email{
"isConfirmed" : true/[or false]
"email" : "xxxxxxxxxxx"
}
当我尝试将isConfirmed
字段更新为真或假时,这取决于显然是唯一的电子邮件,这需要很长时间。
我使用的编程语言是 Java
这是我的代码。
List<String> clientEmails = new ArrayList<String>();
Mongo mongoConnection = new Mongo();
DB mongoDatabase = mongoConnection.getDB(DB_NAME);
DBCollection mongoCollection = mongoDatabase.getCollection(COLLECTION_NAME);
int size = clientEmails.size();
for(int i=0;
i
<
size; i++)
{
BasicDBObject query = new BasicDBObject();
System.out.println(clientEmails.get(i).toString());
query.put("email.email", clientEmails.get(i).toString());
BasicDBObject Update = new BasicDBObject("$set", new BasicDBObject("email.isConfirmed", false));
mongoCollection.update(query, Update);
这需要很长时间才能浏览包含大约 3500 个条目的集合]
//mongoCollection.findAndModify(query, Update);
即使 findAndModify 根本不起作用,我不确定我是否在这里遗漏了什么
但是,我尝试过使用 DBcursor,它可以工作,但运行大约需要 3 分钟。
// DBCursor cursor = mongoCollection.find(query);
//
// while(cursor.hasNext()){
// BasicDBObject Update = new BasicDBObject("$set", new BasicDBObject("email.isConfirmed", true));
// mongoCollection.update(cursor.next(), Update);
// }
此方法大约需要 3 分钟。有人可以建议我解决方法或其他什么吗?