【问题标题】:Mongo find an array inside a collection and get only that dataMongo 在集合中找到一个数组并仅获取该数据
【发布时间】:2018-06-27 23:58:35
【问题描述】:

我怎样才能只从 _id 为 1 的菜单中获取数据?

我试过了:

db.collection("restaurants")
  .find({ name : String(name), "menus._id": Number(id)} )
  .toArray(function (err, result) {

但我仍然可以从餐厅获得完整的结果,而不仅仅是菜单

【问题讨论】:

    标签: json node.js database mongodb


    【解决方案1】:

    您必须使用投影来仅检索菜单字段。

    db.collection("restaurants").find( { name: String(name), "menus._id": Number(id) }, { _id: 0, menus: 1 } ).toArray( function(err,result) { } );
    

    不管有没有投影,默认返回_id字段,您必须通过将_id字段设置为0来关闭它。0表示不显示该字段的值,而1则相反

    【讨论】:

      猜你喜欢
      • 2022-10-13
      • 2021-06-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2014-07-17
      • 1970-01-01
      相关资源
      最近更新 更多