java中mongoTemplate批量更新

方法:mongoTemplate.getDb().getCollection(tableName).bulkWrite(requests);spa

 

public BulkWriteResult bulkWrite(List<WriteModel<Document>> requests,String tableName) {
            BulkWriteResult write = mongoTemplate.getDb().getCollection(tableName).bulkWrite(requests);
return write;
}get

 

BulkWriteResult write = mongoTemplate.getDb().getCollection(tableName).bulkWrite(requests);requests

 

難點在與如何拼接參數List<WriteModel<Document>> requestsit

 

例子:io

DBObject queryObject = new BasicDBObject();
queryObject.put("doctorId",doctorId);
DBObject fields = new BasicDBObject();
fields.put("_id",1);
String tableName = Constant.hospitalInfo.getPrefixNo().toLowerCase()+"-record";
List<Map> map = mongoService.findByMapAndCriteriaMap(queryObject.toString(),fields.toString(),Map.class,
tableName);
List<WriteModel<Document>> requests = new ArrayList<WriteModel<Document>>();  //建立參數集合
for(int i=0;i<map.size();i++){
   Document queryDocument = new Document("_id",map.get(i).get("_id"));  //條件
   Document updateDocument = new Document("$set",new Document(temp.getColName(),dataResult[i]));  //更改信息
   UpdateOneModel<Document> uom = new UpdateOneModel<Document>(queryDocument,updateDocument,new UpdateOptions().upsert(false));  
   requests.add(uom);  
}
 BulkWriteResult bulkWriteResult = mongoService.bulkWrite(requests,tableName);
相關文章
相關標籤/搜索