mongoose populate 返回 指定 字段

1、mongoose中一个数据模型Product(商品)关联另外一个数据模型Brand(品牌)需要使用ref,关联查询使用populate
Product模型

new mongoose.Schema({
  // 商品名称
  name: { type: String, required: true, validate: /\S+/ },
  // 商品内容
  content: { type: String, required: true, validate: /\S+/ },
  // 关联的品牌
  brand: { type: mongoose.Schema.Types.ObjectId, ref: 'Brand' }
  ...

Brand模型

new mongoose.Schema({
  // 品牌
  name: { type: String, required: true, validate: /\S+/ },
  // 品牌图片
  img: { type: String, required: true, validate: /\S+/ }
  ...

2、查询使用populate

// 过滤条件
const options = {
  sort: { _id: -1 },
  page: Number(page),
  limit: Number(size),
  // populate: ['brand', 'tag'],
  populate: [{ path: 'brand', select: 'name' }, 'tag'],
  select: '-password -content'
};
 // 查询参数
  const keywordReg = new RegExp(keyword)
  const query = {
    "$or": [
      { 'name': keywordReg },
      { 'slug': keywordReg },
      { 'description': keywordReg }
    ]
  }
 const ones = await Product.paginate(query, options)

3、注意上段代码中

populate: ['brand', 'tag'],

brand所有字段都返回

populate: [{ path: 'brand', select: 'name' }, 'tag'],

brand返回name字段

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值