在前面的几个章节中我们已经学习了mongodb中如何为集合添加数据和更新数据。在本章节中我们将继续学习mongodb集合的删除。
mongodb remove()函数是用来移除集合中的数据。
mongodb数据更新可以使用update()函数。在执行remove()函数前先执行find()命令来判断执行的条件是否正确,这是一个比较好的习惯。
remove() 方法的基本语法格式如下所示:
db.collection.remove( <query>, <justone> )
如果你的 mongodb 是 2.6 版本以后的,语法格式如下:
db.collection.remove( <query>, { justone: <boolean>, writeconcern: <document> } )
参数说明:
以下文档我们执行两次插入操作:
>db.col.insert({title: 'mongodb 教程', description: 'mongodb 是一个 nosql 数据库', by: 'w3cschool', url: 'http://www.w3cschool.cn', tags: ['mongodb', 'database', 'nosql'], likes: 100 })
使用 find() 函数查询数据:
> db.col.find() { "_id" : objectid("56066169ade2f21f36b03137"), "title" : "mongodb 教程", "description" : "mongodb 是一个 nosql 数据库", "by" : "w3cschool", "url" : "http://www.w3cschool.cn", "tags" : [ "mongodb", "database", "nosql" ], "likes" : 100 } { "_id" : objectid("5606616dade2f21f36b03138"), "title" : "mongodb 教程", "description" : "mongodb 是一个 nosql 数据库", "by" : "w3cschool", "url" : "http://www.w3cschool.cn", "tags" : [ "mongodb", "database", "nosql" ], "likes" : 100 }
接下来我们移除 title 为 'mongodb 教程' 的文档:
>db.col.remove({'title':'mongodb 教程'}) writeresult({ "nremoved" : 2 }) # 删除了两条数据 >db.col.find() …… # 没有数据
如果你只想删除第一条找到的记录可以设置 justone 为 1,如下所示:
>db.collection_name.remove(deletion_criteria,1)
如果你想删除所有数据,可以使用以下方式(类似常规 sql 的 truncate 命令):
>db.col.remove({}) >db.col.find() >