MongoDB 查询文档
1. 查询数据
在 MongoDB 集合中查找并选择数据主要有两种方法:find() 和 findOne()。
2. find()
要在 MongoDB 的集合中选择数据,我们可以使用 find() 方法。
该方法接受一个查询对象。如果留空,则会返回所有文档。
示例
db.posts.find()3. findOne()
若要仅选择单个文档,我们可以使用 findOne() 方法。
该方法接受一个查询对象。如果留空,它将返回找到的第一条文档。
注意: 该方法仅返回它找到的第一条匹配项。
示例
db.posts.findOne()4. 过滤数据
为了查询或过滤数据,我们可以在 find() 或 findOne() 方法中包含一个查询条件。
示例
db.posts.find( {category: "News"} )5. 投影 (Projection)
这两种查询方法都接受第二个参数,称为 投影 (projection)。
该参数是一个描述结果中应包含哪些字段的对象。
注意: 此参数是可选的。如果省略,结果中将包含所有字段。
示例
此示例将在结果中仅显示 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 字段。你应该明确指定你想要包含的字段,或者是你想要排除的字段。
让我们排除 category 字段。结果中将包含所有其他字段。
示例
db.posts.find({}, {category: 0})如果你尝试在同一个对象中同时指定 0 和 1,你会收到一个错误。
示例
db.posts.find({}, {title: 1, date: 0})