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


当前回答

在蒙戈壳里:

use [database];
db.dropDatabase();

并删除用户:

db.dropAllUsers();

其他回答

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

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

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

对于Meteor开发者。

在localhost:3000中运行应用程序时打开第二个终端窗口。 在项目的文件夹中运行,meteor mongo。 coolName = new Mongo.Collection('yourCollectionName'); 然后输入db.yourCollectionName.drop(); 您将自动在本地服务器中看到更改。

为了其他人。

db.yourCollectionName.drop ();

我遵循了db.dropDatabase()路线很长一段时间,但是,如果您试图在测试用例之间使用它来删除数据库,您最终可能会发现数据库删除后索引约束没有得到尊重的问题。因此,你要么需要处理ensureIndexes,要么一个更简单的方法是避免dropDatabase,只从循环中的每个集合中删除,比如:

db.getCollectionNames().forEach(
  function(collection_name) {
    db[collection_name].remove()
  }
);

在我的情况下,我从命令行运行这个使用:

mongo [database] --eval "db.getCollectionNames().forEach(function(n){db[n].remove()});"

如果你只想删除一个数据库和它的子集合,使用这个:

使用<数据库名称>; db.dropDatabase ();

如果你想删除mongo中的所有数据库,请使用以下命令:

db.adminCommand("listDatabases").databases.forEach(function(d)
             {
              if(d.name!="admin" && d.name!="local" && d.name!="config")
                {
                 db.getSiblingDB(d.name).dropDatabase();
                }
             }
          );
use <dbname>
db.dropAllUsers()
db.dropAllRoles()
db.dropDatabase()

MongoDB db.dropDatabase()文档解释了2.6中引入的修改:

在2.6版更改:此命令不会删除与当前数据库关联的用户。