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


当前回答

列出所有可用的dbs show dbs 选择必要的数据库 使用 删除数据库 db.dropDatabase () //很少额外的命令 列出数据库中所有可用的集合 显示集合 删除一个规范集合 db.collection.drop ()

希望这能有所帮助

其他回答

在MongoDB 3.2及更新版本中,Mongo shell中的Mongo().getDBNames()将在服务器中输出一个数据库名称列表:

> Mongo().getDBNames()
[ "local", "test", "test2", "test3" ]

> show dbs
local  0.000GB
test   0.000GB
test2  0.000GB
test3  0.000GB

遍历数组的forEach()循环然后可以调用dropDatabase()来删除所有列出的数据库。您还可以选择跳过不想删除的一些重要数据库。例如:

Mongo().getDBNames().forEach(function(x) {
  // Loop through all database names
  if (['admin', 'config', 'local'].indexOf(x) < 0) {
    // Drop if database is not admin, config, or local
    Mongo().getDB(x).dropDatabase();
  }
})

示例运行:

> show dbs
admin   0.000GB
config  0.000GB
local   0.000GB
test    0.000GB
test2   0.000GB
test3   0.000GB

> Mongo().getDBNames().forEach(function(x) {
...   if (['admin', 'config', 'local'].indexOf(x) < 0) {
...     Mongo().getDB(x).dropDatabase();
...   }
... })

> show dbs
admin   0.000GB
config  0.000GB
local   0.000GB

在蒙戈壳里:

use [database];
db.dropDatabase();

并删除用户:

db.dropAllUsers();

我遵循了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()});"

当我需要重置所有集合但又不想失去任何数据库用户时,我遇到了同样的问题。如果您想保存数据库的用户配置,请使用以下代码行:

use <whichever database>
db.getCollectionNames().forEach(function(c) { if (c.indexOf("system.") == -1) db[c].drop(); })

这段代码将遍历一个数据库中的所有集合名称,并删除不以“system.”开头的集合名称。

我更喜欢

db.your_collection.remove({})

over

db.your_collection.drop()

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