Mongodb 虚拟字段(virtual)设置

解释已经在代码的注释中

const mongoose = require('mongoose')

//问题表
const schema = new mongoose.Schema({
    name: {type: String},
    desc: {type: String},
    answer: {type: Boolean},//是否必答
    order: {type: Number},
    topic: {type: mongoose.SchemaTypes.ObjectId, ref: 'Topic'},//题型
    question: {type: mongoose.SchemaTypes.ObjectId, ref: 'Question'}//调查问卷
})

schema.virtual('option', {//定义虚拟字段
    ref: 'Option',// 关联的模型
    localField: '_id',// 内键,schema对应的模型Title的_id
    foreignField: 'title',//外键,关联模型Option的title字段
    justOne: false  // 只查询一条数据
})

module.exports = mongoose.model('Title', schema, "Titles")

const mongoose = require('mongoose')

//选项表
const schema = new mongoose.Schema({
    name: {type: String},//选项 :A ,B,C
    content: {type: String},//选项内容
    title: {type: mongoose.SchemaTypes.ObjectId, ref: 'Title'}
})

module.exports = mongoose.model('Option', schema, "Options")

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值