[英]Mongoose nested schema
我想建立一个主题系统。 每个主题都可以具有子主题,这些子主题也是主题。 意味着子主题也可能有子主题。 例如示例图片
我试图创建一个主题架构并添加一个子主题字段,该字段也将引用主题架构。 我的模式代码似乎无法正常工作:
const mongoose = require('mongoose');
const TopicSchema = new mongoose.Schema({
name: {type:String,unique:true},
sub_topic:[{type:mongoose.Schema.Types.ObjectId, ref : 'Topic'}]
});
const Topic =mongoose.model('Topic', TopicSchema);
module.exports = Topic;
即时消息发送到服务器的数据应该看起来像什么来创建新实例? 在服务器上如何保存?
我现在尝试像这样保存:const topic = new Topic();
topic.name = req.body.name;
topic.sub_topic.name=req.body.sub_topic
我发送的数据是:(json)
{
"name":"TestMain",
"sub_topic":[{"name":"TestSub"}]
}
更新:使用递归函数完成此操作。
function subtopicHandler(topic, sub_topic) {
Topic.find({
"name": topic.name
}, function (err, res) {
if (err) throw err
return;
})
if (sub_topic == undefined) {
let ntopic = new Topic();
ntopic.name = topic.name;
ntopic.sub_topic == undefined;
ntopic.save(function (err, result) {
if (err) console.log('saving err', err)
});
return ntopic._id;
}
let mainTopic = new Topic();
mainTopic.name = topic.name;
sub_topic.forEach(function (sub) {
mainTopic.sub_topic.push(subtopicHandler(sub, sub.sub_topic));
})
var retME;
mainTopic.save(function (err, result) {
if (err) {
console.log('saving err', err)
throw err;
}
});
return mainTopic._id;
}
使用此架构:
const TopicSchema = new mongoose.Schema({
name: {type:String,unique:true},
sub_topic:[{type:mongoose.Schema.Types.ObjectId, ref : 'Topic'}]
});
数据发送为:
{
"name":"A",
"sub_topic":[
{"name":"C","sub_topic":
[
{"name":"C1"}
,
{"name":"C2"}
]
}
,
{"name":"B"}
,
{"name":"D","sub_topic":
[
{"name":"D1"}
,
{"name":"D2"}
,
{"name":"D3"}
]
}
]
}
API端点以这种方式处理:
let mainTopic = new Topic();
mainTopic.name = req.body.name;
subtopicHandler(mainTopic, req.body.sub_topic);
})
如果您正在发送以下json
const obj = {
"name":"TestMain",
"sub_topic":[{"name":"TestSub"}]
}
然后,
let mainTopic = new Topic();
let subTopic = new Topic();
// assuming for now you have only one sub-topic in array
subTopic.name = obj[0].name;
subTopinc.save(function(err,result)=>{
if(!err){
mainTopic.name = obj.name;
mainTopic.sub_topic = [result._id]
mainTopic.save(function(err,result){
console.log(result);
})
}
});
从您的架构定义和给定的json中,您可以按照上述步骤获取结果。
希望这会帮助你。
您可以使用子文档来执行此操作,以查看文档。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.