collection.find() 总是返回 MongoDB 的所有字段?
您可以使用以下语法从collection.find()返回特定字段。
情况1 - 语法如下 -
db.yourCollectionName.find({},{"yourFieldName":1}).pretty();
上面的字段名称设置为 1 意味着它将仅返回该字段。如果设置为 0,它将返回除设置为 0 的字段之外的所有字段。
情况 2 - 语法如下 -
db.yourCollectionName.find({},{"yourFieldName":0}).pretty();
为了理解上述语法,让我们用 document 创建一个集合。使用文档创建集合的查询如下 -
> db.returnFieldInFindDemo.insertOne({"StudentName":"John","StudentAge":23,"TechnicalSubject":["MongoDB","MySQL"]}); { "acknowledged" : true, "insertedId" : ObjectId("5c8ebfe72f684a30fbdfd566") } > db.returnFieldInFindDemo.insertOne({"StudentName":"Mike","StudentAge":24,"TechnicalSubject":["Java","Python"]}); { "acknowledged" : true, "insertedId" : ObjectId("5c8ebffd2f684a30fbdfd567") } > db.returnFieldInFindDemo.insertOne({"StudentName":"Sam","StudentAge":22,"TechnicalSubject":["C","C++"]}); { "acknowledged" : true, "insertedId" : ObjectId("5c8ec00f2f684a30fbdfd568") } > db.returnFieldInFindDemo.insertOne({"StudentName":"Carol","StudentAge":20,"TechnicalSubject":["DataStructure","Algorithm"]}); { "acknowledged" : true, "insertedId" : ObjectId("5c8ec0292f684a30fbdfd569") }
借助 find() 方法显示集合中的所有文档。查询如下 -
> db.returnFieldInFindDemo.find().pretty();
以下是输出 -
{ "_id" : ObjectId("5c8ebfe72f684a30fbdfd566"), "StudentName" : "John", "StudentAge" : 23, "TechnicalSubject" : [ "MongoDB", "MySQL" ] } { "_id" : ObjectId("5c8ebffd2f684a30fbdfd567"), "StudentName" : "Mike", "StudentAge" : 24, "TechnicalSubject" : [ "Java", "Python" ] } { "_id" : ObjectId("5c8ec00f2f684a30fbdfd568"), "StudentName" : "Sam", "StudentAge" : 22, "TechnicalSubject" : [ "C", "C++" ] } { "_id" : ObjectId("5c8ec0292f684a30fbdfd569"), "StudentName" : "Carol", "StudentAge" : 20, "TechnicalSubject" : [ "DataStructure", "Algorithm" ] }
情况 1 - 这是您将返回特定字段的查询。
查询如下 -
> db.returnFieldInFindDemo.find().pretty();
输出:
{ "_id" : ObjectId("5c8ebfe72f684a30fbdfd566"), "StudentName" : "John", "StudentAge" : 23, "TechnicalSubject" : [ "MongoDB", "MySQL" ] } { "_id" : ObjectId("5c8ebffd2f684a30fbdfd567"), "StudentName" : "Mike", "StudentAge" : 24, "TechnicalSubject" : [ "Java", "Python" ] } { "_id" : ObjectId("5c8ec00f2f684a30fbdfd568"), "StudentName" : "Sam", "StudentAge" : 22, "TechnicalSubject" : [ "C", "C++" ] } { "_id" : ObjectId("5c8ec0292f684a30fbdfd569"), "StudentName" : "Carol", "StudentAge" : 20, "TechnicalSubject" : [ "DataStructure", "Algorithm" ] }
看看上面的示例输出,我已将“TechnicalSubject”字段初始化为 1。这意味着它将仅从所有文档中返回“TechnicalSubject”字段。
情况 2
情况 2
strong> - 在第二种情况下,如果将“TechnicalSubject”字段设置为0,则意味着您将获得除“TechnicalSubject”之外的所有字段。查询如下 -
> db.retunFieldInFindDemo.find({},{"TechnicalSubject":0}).pretty();
以下是输出:
{ "_id" : ObjectId("5c8ebfe72f684a30fbdfd566"), "StudentName" : "John", "StudentAge" : 23 } { "_id" : ObjectId("5c8ebffd2f684a30fbdfd567"), "StudentName" : "Mike", "StudentAge" : 24 } { "_id" : ObjectId("5c8ec00f2f684a30fbdfd568"), "StudentName" : "Sam", "StudentAge" : 22 } { "_id" : ObjectId("5c8ec0292f684a30fbdfd569"), "StudentName" : "Carol", "StudentAge" : 20 }
情况 3 - 如您所知,如果您仅使用 find() 那么它会返回所有字段。
查询如下 -
> db.retunFieldInFindDemo.find();
以下是输出:
{ "_id" : ObjectId("5c8ebfe72f684a30fbdfd566"), "StudentName" : "John", "StudentAge" : 23, "TechnicalSubject" : [ "MongoDB", "MySQL" ] } { "_id" : ObjectId("5c8ebffd2f684a30fbdfd567"), "StudentName" : "Mike", "StudentAge" : 24, "TechnicalSubject" : [ "Java", "Python" ] } { "_id" : ObjectId("5c8ec00f2f684a30fbdfd568"), "StudentName" : "Sam", "StudentAge" : 22, "TechnicalSubject" : [ "C", "C++" ] } { "_id" : ObjectId("5c8ec0292f684a30fbdfd569"), "StudentName" : "Carol", "StudentAge" : 20, "TechnicalSubject" : [ "DataStructure", "Algorithm" ] }
以上是collection.find() 总是返回 MongoDB 的所有字段?的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

本文讨论了在MongoDB中创建用户和角色,管理权限,确保安全和自动化这些过程。它强调了最佳实践,例如最低特权和基于角色的访问控制。

本文讨论了在MongoDB中选择一个碎片钥匙,并强调了其对性能和可伸缩性的影响。主要考虑因素包括高基数,查询模式和避免单调增长。

本文解释了如何使用MongoDB Compass(用于管理和查询MongoDB数据库的GUI)。 它涵盖了连接,导航数据库,使用视觉构建器查询,数据操作以及导入/导出。 虽然对较小的数据有效

本文讨论了各种MongoDB索引类型(单,化合物,多键,文本,地理空间)及其对查询性能的影响。它还涵盖了根据数据结构和查询需求选择正确索引的注意事项。

MongoDB Compass是用于管理和查询MongoDB数据库的GUI工具。它提供数据探索,复杂查询执行和数据可视化的功能。

本文讨论了配置MongoDB审计安全性合规性,详细介绍了启用审核,设置审核过滤器并确保日志符合监管标准的步骤。主要问题:适当的配置和分析审核日志的安全

本文详细介绍了如何使用变更流,聚合管道和各种存储选项(其他MongoDB集合,外部数据库,消息队列)在MongoDB中实施审核。 它强调性能优化(过滤,

本文通过基于云的NOSQL数据库MongoDB Atlas引导用户。 它涵盖了设置,集群管理,数据处理,扩展,安全性和优化策略,突出了自托管的蒙古德(Mongodb)的关键差异并强调
