带有通配符的Mongodb Shell丢弃集合

问题描述

我有一堆具有相同前缀的集合,例如data_user_1,data_user_2等。 我还想保留其中的一些收藏夹,以免丢失。

所以我正在寻找解决方

a)全部删除排除特定 b)删除所有data_user _ *

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

解决方法

不幸的是,没有这样的选择。

  1. 您可以使用getCollectionNames

    检索所有可用的集合
  2. 然后您可以检查包含/排除方案。

  3. 条件匹配时,您可以对其进行drop

,

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

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

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

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...