MongoDB mongosh 查找
查找数据
在 MongoDB 集合中查找和选择数据有两种方法:find()
和 findOne()
。
find()
要从 MongoDB 中的集合中选择数据,我们可以使用 find()
方法。
该方法接受一个查询对象。如果留空,将返回所有文档。
实例
db.posts.find()
findOne()
要仅选择一个文档,我们可以使用 findOne()
方法。
该方法接受一个查询对象。如果留空,它将返回找到的第一个文档。
注意:此方法仅返回它找到的第一个匹配项。
实例
db.posts.findOne()
查询数据
要查询或过滤数据,我们可以在 find()
或 findOne()
方法中包含查询。
实例
db.posts.find( {category: "News"} )
投影
两种 find 方法都接受第二个参数,称为投影。
该参数是一个对象,描述结果中包含哪些字段。
注意:该参数是可选的。如果省略,结果中将包含所有字段。
实例
此例仅在结果中显示 title
和 date
字段。
db.posts.find({}, {title: 1, date: 1})
请注意,_id
字段也包括在内。除非明确排除,否则始终包含此字段。
我们使用 1
来包含字段,使用 0
来排除字段。
实例
这次,我们排除 _id
字段。
db.posts.find({}, {_id: 0, title: 1, date: 1})
注意:不能在同一个对象中同时使用 0 和 1。唯一的例外是 _id
字段。您应该指定要包含的字段或要排除的字段。
让我们排除日期类别字段。所有其他字段都将包含在结果中。
实例
db.posts.find({}, {category: 0})
如果我们尝试在同一个对象中同时指定 0 和 1,将会收到错误。
实例
db.posts.find({}, {title: 1, date: 0})