0

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

所以我寻找解决方案

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

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

4

2 回答 2

2

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

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

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

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

于 2020-10-29T13:17:56.107 回答
1

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

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

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

于 2020-10-29T13:31:17.813 回答