springboot整合mongodb批量修改和添加索引,与设置mongodb保存更新超时时间

1:创建字段索引

collection 是集合名称,keys 是一个包含一个或多个字段名,options是排序方向,1正序,-1倒叙

db.collection.createIndex(keys, options)
#单字段
db.collection.createIndex(name: 1)
#多字段
db.collection.createIndex{name: 1, age: -1}

2:mongodb批量修改

BulkOperations bulkOperations = mongoTemplate.bulkOps(BulkMode.UNORDERED, RealtimeEntity.class);

updateList.forEach(realtimeEntity -> {
    Query query = new Query(Criteria.where("pn").is(realtimeEntity.getPn()));
    Update update = new Update()
            .set("pnVal", realtimeEntity.getPnVal())
            .set("tm", realtimeEntity.getTm())
            .set("rm", realtimeEntity.getRm());

    bulkOperations.updateOne(query, update);
});
bulkOperations.execute();

注意:必须创建索引这样更新的效率快

3:mongodb保存的时候最好设置一个保存超时时间,因为mongodb本身没有设置保存或者更新超时抛出异常

	public void saveWithTimeout(Object objectToSave, String collectionName) {
        CompletableFuture<Void> completableFuture = new CompletableFuture<>();
        
        mongoTemplate.insert(objectToSave, collectionName).addCallback(
            result -> completableFuture.complete(null),
            ex -> completableFuture.completeExceptionally(ex)
        );
        
        try {
            completableFuture.get(10, TimeUnit.SECONDS);
        } catch (TimeoutException e) {
            // 超时处理逻辑,例如抛出异常或记录日志
            throw new RuntimeException("保存超时");
        } catch (InterruptedException | ExecutionException e) {
            // 异常处理逻辑
            throw new RuntimeException("保存失败:" + e.getMessage());
        }
    }

3-1:mongoTemplate通过id主机查询,需要设置主机类型为objectId不然通过主机查不出来数据,或者在数据库添加字段_id类型为sting覆盖本身的自带的objectId类型

4:在Spring Boot中,你可以通过在application.yml或application.properties文件中设置相关属性来配置MongoDB的保存和更新操作的超时时间。

下面是在application.yml文件中配置MongoDB超时时间的示例:

spring:
  data:
    mongodb:
      write-concern:
        w: majority
        wtimeout: 10000

在上述示例中,w: majority表示写操作需要大多数节点确认,wtimeout: 10000表示写操作的超时时间为10秒。

如果你只想设置保存操作的超时时间,可以使用以下配置:

spring:
  data:
    mongodb:
      write-concern:
        wtimeout: 10000

同样地,如果你只想设置更新操作的超时时间,可以使用以下配置:

spring:
  data:
    mongodb:
      update-timeout: 10000

mongodb开启自动创建唯一索引@Indexed(unique = true)

spring: 
    data: 
        mognodb: 
            auto-index-creation: true

请根据你的具体需求选择合适的配置方式,并根据实际情况调整超时时间。

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值