mongodb 表之间的关联查询

cate 表

const mongoose = require('mongoose');
const { Schema, model } = mongoose;
const CateSchema = new Schema({
    // 标题
    title: { type: String, required: true },
}, { timestamps: true });

module.exports = model('cate', CateSchema); 

food表

const mongoose = require('mongoose');
const { Schema, model } = mongoose;
const FoodSchema = new Schema({
    // 标题
    title: { type: String, required: true },
    // 分类
    cate_id: {
        type: Schema.Types.ObjectId,
        ref: 'cate', // cate 表 的model name
    },
}, { timestamps: true });
module.exports = model('food', FoodSchema);
  • 在 food 的控制层 内 执行查询操作

populate 的是关联表之间的查询 , 通过food表中的cate_id 和 cate表的_id相互关联
populate 的第一个参数是表关联之间的纽带,第二个参数表示过滤参数即是否返回当前参数,1 表示返回, 0 表示不反悔。
populate可以写多个串联,populate(‘cate_id’).populate(‘test_id’)…populate(‘demo_id’)… 需要在foo的表中先建立关系

    // 详情
    async findOne(ctx) {
            const { id: _id } = ctx.query
            const detail = await Food.find({ _id }).populate('cate_id', { title: 1, _id: 1 })
    }

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值