我在MongoDB上做开发。出于完全无害的目的,我有时想要删除数据库中的所有内容——也就是说,删除每一个集合,以及周围可能存在的任何其他内容,然后从头开始。是否有一行代码可以让我这样做?同时提供MongoDB控制台方法和MongoDB Ruby驱动程序方法的额外好处。
当前回答
我更喜欢
db.your_collection.remove({})
over
db.your_collection.drop()
如果你的收藏是特别的收藏 例如,一个有上限的集合或一个字段被标记为唯一的集合,删除将清除集合本身,当再次创建集合时,它将是一个普通的集合。您必须重新定义属性。 因此,使用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();
}
}
);
如果你需要立即删除所有数据库:(立即删除所有数据库)
mongo --quiet --eval 'db.getMongo().getDBNames().forEach(function(i){db.getSiblingDB(i).dropDatabase()})'
对于Meteor开发者。
在localhost:3000中运行应用程序时打开第二个终端窗口。 在项目的文件夹中运行,meteor mongo。 coolName = new Mongo.Collection('yourCollectionName'); 然后输入db.yourCollectionName.drop(); 您将自动在本地服务器中看到更改。
为了其他人。
db.yourCollectionName.drop ();
删除所有db使用:
for i in $(mongo --quiet --host $HOSTNAME --eval "db.getMongo().getDBNames()" | tr "," " ");
do mongo $i --host $HOSTNAME --eval "db.dropDatabase()";
done
我遵循了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()});"
推荐文章
- elasticsearch vs . MongoDB用于过滤应用程序
- MongoDB记录所有查询
- MongoDB:如何找到安装的MongoDB的确切版本
- 如何使用mongoimport导入CSV文件?
- 在mongodb中存储日期/时间的最佳方法
- 如何排序mongodb与pymongo
- 如何在mongodb上导入。bson文件格式
- JSON文件的蒙古导入
- 如何删除mongodb中的数组元素?
- 修改MongoDB数据存储目录
- 在MongoDB中查找重复的记录
- 为什么MongoDB Java驱动在条件中使用随机数生成器?
- 在猫鼬,我如何排序的日期?(node . js)
- 将映像存储在MongoDB数据库中
- 重复Mongo ObjectId的可能性在两个不同的集合中生成?