我在MongoDB上做开发。出于完全无害的目的,我有时想要删除数据库中的所有内容——也就是说,删除每一个集合,以及周围可能存在的任何其他内容,然后从头开始。是否有一行代码可以让我这样做?同时提供MongoDB控制台方法和MongoDB Ruby驱动程序方法的额外好处。


当前回答

Use

[databaseName]
db.Drop+databaseName();

drop collection 

use databaseName 
db.collectionName.drop();

其他回答

这里有一些有用的删除操作mongodb使用mongo shell

删除集合中的特定文档。删除({name:"stack"})

删除集合中的所有文档:db.mycollection.remove()

删除任何特定集合:db.mycollection.drop()

删除数据库。 首先使用mydb命令进入该数据库,然后

db.dropDatabase()

Use

[databaseName]
db.Drop+databaseName();

drop collection 

use databaseName 
db.collectionName.drop();

通过编译@Robse和@DanH的答案,我得到了以下完全让我满意的解决方案:

db.getCollectionNames().forEach( function(collection_name) { 
  if (collection_name.indexOf("system.") == -1) 
       db[collection_name].drop();
  else  
       db[collection_name].remove({});
});

它通过删除用户集合和清空系统集合来清理数据库。

删除所有db使用:

for i in $(mongo --quiet --host $HOSTNAME --eval "db.getMongo().getDBNames()" | tr "," " ");

do mongo $i --host $HOSTNAME --eval "db.dropDatabase()";

done 

我更喜欢

db.your_collection.remove({})

over

db.your_collection.drop()

如果你的收藏是特别的收藏 例如,一个有上限的集合或一个字段被标记为唯一的集合,删除将清除集合本身,当再次创建集合时,它将是一个普通的集合。您必须重新定义属性。 因此,使用remove()在不删除集合和影响集合行为的情况下清除文档。