流水乐年 2021-02-27 03:27 采纳率: 50%
浏览 54
已采纳

关于mongoDB关联查询中参数前面“-”的问题求解~~~

最近在自学前端过程中,遇到mongodb关联查询问题,在populate(),select(),sort()等方法传递了('-author -category'),('author', '-password'),('-content -meta')等参数,不是很理解,不是直接传递参数或者对象吗,参数前加“-”是什么意思,自己在网站找教程也没有详细讲解,还望大神能指教下,顺便给个mongose的入门教程,不胜感激~~~

// 查询文章信息
const posts = await pagination(Post).page(page).size(10).display(5)
.find(condition).populate('author', '-password')
.populate('category')
.select('-content -meta')
.exec();

 

  • 写回答

1条回答 默认 最新

  • 幻灰龙 2021-02-27 09:54
    关注

    知识点:

    • 首先,我们知道关系型数据库(例如 MySQL )关联查询用的是 join 语句,而文档数据库 Mongodb 原生的关联查询是使用 lookup 语句。而你用的是为 Mongodb 提供的封装库 Mongoose ,这个库提供了便利的关联查询方法 populate.
    • 其次,populate 的第2个参数表示要查询的关联表里的字段,多个字段用空格分隔,select 里的参数也表示要选择的字段,多个字段用空格分隔。
    • 最后,横杆 '-field' 表示不查询某个字段(反向排除字段)

     

    参考:

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥35 引用csv数据文件(4列1800行),通过高斯-赛德尔法拟合曲线,在选取(每五十点取1点)数据,求该数据点的曲率中心。
  • ¥20 程序只发送0X01,串口助手显示不正确,配置看了没有问题115200-8-1-no,如何解决?
  • ¥15 Google speech command 数据集获取
  • ¥15 vue3+element-plus页面崩溃
  • ¥15 像这种代码要怎么跑起来?
  • ¥15 怎么改成循环输入删除(语言-c语言)
  • ¥15 安卓C读取/dev/fastpipe屏幕像素数据
  • ¥15 pyqt5tools安装失败
  • ¥15 mmdetection
  • ¥15 nginx代理报502的错误