MongoDB 使用 mongosh 查找

查找数据

有两种方法可以从 MongoDB 集合中查找和选择数据, find()findOne().

find()

要从 MongoDB 中的集合中选择数据,我们可以使用 find() 方法。

此方法接受查询对象。如果保留为空,将返回所有文档。

实例
  1. db.posts.find()

findOne()

要只选择一个文档,我们可以使用 findOne() 方法。

此方法接受查询对象。如果留空,它将返回找到的第一个文档。

注意:此方法只返回它找到的第一个匹配项。
实例
  1. db.posts.findOne()

查询数据

要查询或过滤数据,我们可以在 find()findOne() 方法中包含一个查询。

实例
  1. db.posts.find( {category: "News"} )

Projection(投影)

这两个 find 方法都接受第二个称为 projection(投影)的参数。

此参数是一个对象,用于描述要包含在结果中的字段。

注意:此参数为可选参数。如果省略,所有字段都将包含在结果中。
实例

此实例将仅显示结果中的 titledate 字段。

  1. db.posts.find({}, {title: 1, date: 1})
请注意_id 字段也包含在内。除非特别排除,否则始终包括此字段。

我们使用 1 来包含字段,使用 0 来排除字段。

实例

这一次,让我们排除 _id 字段。

  1. db.posts.find({}, {_id: 0, title: 1, date: 1})
注意:不能在同一个对象中同时使用 01。唯一的例外是 _id 字段。您应该指定要包括的字段或要排除的字段。

让我们排除日期类别字段。所有其他字段都将包含在结果中。

实例
  1. db.posts.find({}, {category: 0})

如果我们试图在同一个对象中同时指定 01,则会出现错误。

实例
  1. db.posts.find({}, {title: 1, date: 0})