【问题标题】:Mongodb shell drop collections with wild card带有通配符的 Mongodb shell drop 集合
【发布时间】:2020-10-29 13:04:25
【问题描述】:

我有一堆具有相同前缀的集合,例如data_user_1、data_user_2 等 还有一些我想保留和跳过的集合。

所以我在寻找解决方案

a) 删除所有排除特定的 b) 删除所有 data_user_*

我搜索了docs,但似乎没有允许任何这些操作的参数。 谢谢

【问题讨论】:

    标签: mongodb mongo-shell mongo-collection


    【解决方案1】:

    很遗憾,没有这样的选择。

    1. 您可以使用getCollectionNames检索所有可用的集合

    2. 然后您可以检查包含/排除方案。

    3. 当条件匹配时,可以对其执行drop

    【讨论】:

    • 谢谢。我将解决方案发布为答案
    【解决方案2】:

    我放弃搜索,因为似乎没有“舒适”的方式。所以我写了一个简短的脚本来满足要求(而且也很舒服^^)。

    db.getCollectionNames().forEach(function(collname){
    if(collname.includes('data_user')){ 
     print('delete collection: ' + collname); 
     db.getCollection(collname).drop()}
    });
    

    希望这对其他人也有帮助。

    【讨论】:

      猜你喜欢
      • 2020-08-21
      • 1970-01-01
      • 2017-04-28
      • 1970-01-01
      • 2012-10-31
      • 2020-06-16
      • 2012-02-10
      • 1970-01-01
      相关资源
      最近更新 更多