欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MongoDB快速入门笔记(六)之MongoDB删除文档操作

程序员文章站 2022-07-06 13:55:14
mongodb是一个跨平台,面向文档的数据库,提供高性能,高可用性和易于扩展。mongodb是工作在集合和文档上一种概念。 文档是一组键值对。文档具有动态模式。动态模...

mongodb是一个跨平台,面向文档的数据库,提供高性能,高可用性和易于扩展。mongodb是工作在集合和文档上一种概念。

文档是一组键值对。文档具有动态模式。动态模式是指,在同一个集合的文件不必具有相同一组集合的文档字段或结构,并且相同的字段可以保持不同类型的数据。

db.集合名称.remove({query}, justone)

query:过滤条件,可选

justone:是否只删除查询到的第一条数据,值为true或者1时,只删除一条数据,默认为false,可选。

准备数据:把_id为1和2的age都变成28

> db.student.update({_id:1},{$set:{age:28}})
writeresult({ "nmatched" : 1, "nupserted" : 0, "nmodified" : 1 })
> db.student.update({_id:2},{$set:{age:28}})
writeresult({ "nmatched" : 1, "nupserted" : 0, "nmodified" : 1 })
> db.student.find()
{ "_id" : 1, "name" : "zhangsan", "age" : 28 }
{ "_id" : 2, "name" : "lisi", "age" : 28 }
{ "_id" : 3, "name" : "wangwu", "age" : 30 }
{ "_id" : 4, "name" : "zhaoliu", "age" : 28 }
{ "_id" : 5, "name" : "qianliu", "age" : 33 }
{ "_id" : 6, "name" : "sunba", "age" : 32 }
{ "_id" : 7, "name" : "songjiu", "skill" : [ "mongodb", "java" ] }

1、使用两个参数:

删除age=28的第一条数据

> db.student.remove({age:28}, true)
writeresult({ "nremoved" : 1 })
> db.student.find()
{ "_id" : 2, "name" : "lisi", "age" : 28 }
{ "_id" : 3, "name" : "wangwu", "age" : 30 }
{ "_id" : 4, "name" : "zhaoliu", "age" : 28 }
{ "_id" : 5, "name" : "qianliu", "age" : 33 }
{ "_id" : 6, "name" : "sunba", "age" : 32 }
{ "_id" : 7, "name" : "songjiu", "skill" : [ "mongodb", "java" ] } 

2、使用一个参数:

删除age=28的所有数据

> db.student.remove({age:28})
writeresult({ "nremoved" : 2 })
> db.student.find()
{ "_id" : 3, "name" : "wangwu", "age" : 30 }
{ "_id" : 5, "name" : "qianliu", "age" : 33 }
{ "_id" : 6, "name" : "sunba", "age" : 32 }
{ "_id" : 7, "name" : "songjiu", "skill" : [ "mongodb", "java" ] } 

3、删除集合的全部数据,括号中的“{}”必须有,表示空的过滤条件:

> db.student.remove({})
writeresult({ "nremoved" : 4 }) 

另外使用remove()方法删除的时候,只是删除数据,表还会存在。使用drop()方法会把表也删除,并且drop()的效率要比remove()效率高很多。