首页 > 数据库技术 > 详细

MongoDB实现批量存在执行修改,不存在执行添加(BulkWrite)

时间:2020-08-15 13:35:48      阅读:192      评论:0      收藏:0      [点我收藏+]

最近使用mongodb实现一个需求,需要批量处理数据,并且存在则修改,不存在则添加,updateMany方法,无法达到要求,经查,发现mongodb中存在一个BulkWrite方法可以实现该需求,该操作可实现类似于mysql的insert into ... on duplicate key udpdate ...

使用如下命令创建用于测试的db和collection以及添加index并查看

use mockdb
db.mockcoll.createIndex({"flag":1})
db.mockcoll.getIndexes()

mockcoll中只存在一个字段flag,并在该字段建立唯一索引

下面为代码示例

public interface MongoCons {

    String mockdbName = "mockdb";
    String mockcollName = "mockcoll";
    
    static MongoCollection<Document> getCollection(MongoTemplate mongoTemplate){
        MongoDatabase mongoDatabase = mongoTemplate.getMongoDbFactory().getMongoDatabase(mockdbName);
        MongoCollection<Document> collection = mongoDatabase.getCollection(mockcollName);
        return collection;
    }
    
}

 

@Component
public class MongoBulkDao {

    private Logger logger = LoggerFactory.getLogger(MongoBulkDao.class);
    @Autowired
    private MongoTemplate mongoTemplate;

    public void addOrUpdate(List<String> dataList) {
        try {
            MongoCollection<Document> collection = MongoCons.getCollection(mongoTemplate);

            List<WriteModel<Document>> list = new ArrayList<>();

            Iterator<String> iterator = dataList.iterator();
            String next = null;
            while (iterator.hasNext()) {
                next = iterator.next();
                BasicDBObject filter = new BasicDBObject().append("flag", next);
                BasicDBObject update = new BasicDBObject().append("$set", new BasicDBObject().append("flag", next));

                UpdateOneModel<Document> um = new UpdateOneModel<Document>(filter, update,
                        new UpdateOptions().upsert(true));
                list.add(um);
                iterator.remove();
            }

            collection.bulkWrite(list, new BulkWriteOptions().ordered(false));
        } catch (Exception e) {
            logger.error("",e);
        }
    }

 上述代码那种调用了bulkWrite的其中一个构造方法,new BulkWriteOptions().ordered(false)中orderd默认为ture,即如果其中一条执行错误,后面的将不再执行,为false,其中的一条执行错误,跳过去,继续执行下面的命令。

技术分享图片

 

MongoDB实现批量存在执行修改,不存在执行添加(BulkWrite)

原文:https://www.cnblogs.com/qq931399960/p/13508246.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!