我需要在模式中保存一些子文档,该模式是模式的子文档。 保存功能是:
exports.add = function(req, res){
var cliente = new Cliente(req.body);
var sedi = [];
for(var key in req.body.sede){
var sede = new Sede(req.body.sede[key]);
var luoghi_consegna_sedi = [];
for(jey in req.body.sede[key].lcs){
var luogo_consegna_sede = new LuoghiConsegnaSede(req.body.sede[key].lcs[jey]);
//Sub document
luoghi_consegna_sedi.push(luogo_consegna_sede);
}
sede.luoghi_consegna_sedi = luoghi_consegna_sedi;
//Sub docuemnt
sedi.push(sede);
}
cliente.sedi = sedi;
cliente.save(function(err){
if(err)
return res.sendStatus(400);
return res.json(cliente);
});
};
问题是顶级父模式(cliente)保存在mongoldb上,而两种类型的子文档则没有。在cliente.sedi中,数组中填充了sede objectid,但是在mongoldb上,sede表不存在(对于luoghi_consegna_sedi也是如此)。 如果我在将它们推入数组之前手动保存sede和luoghi_consegna_sedi,则会创建两个表并填充数据,但如果我在cliente.sedi上运行populate(),我会得到一个空数组。 3个架构是这些: Cliente
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
var ClienteSchema = new Schema({
data_status: String,
status_cliente: Number,
titolo_cliente: String,
cognome: String,
nome: String,
ragione_sociale: String,
codice_fiscale: String,
partita_iva: String,
data_nascita: String,
luogo_nascita: String,
business: {
type: Boolean,
default: false
},
consumer: {
type: Boolean,
default: false
},
sedi: {
type: [Schema.ObjectId],
ref: 'Sede'
},
eliminato: {
type: Boolean,
default: false
},
created: {
type: Date,
default: Date.now
}
});
ClienteSchema.set('toJSON', {getters: true});
mongoose.model('Cliente', ClienteSchema);
塞德
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
var SedeSchema = new Schema({
denominazione_sede: String,
tipo_sede: String,
tipo_indirizzo: String,
indirizzo: String,
numero_civico: String,
citofonare: String,
interno: String,
piano: String,
scala: String,
citta: String,
provincia: String,
cap: String,
regione: String,
paese: String,
telefono_1: String,
telefono_2: String,
email: String,
agente_assegnato_1: {
type: Schema.ObjectId,
ref: 'User'
},
agente_assegnato_2: {
type: Schema.ObjectId,
ref: 'User'
},
agente_assegnato_3: {
type: Schema.ObjectId,
ref: 'User'
},
agente_assegnato_4: {
type: Schema.ObjectId,
ref: 'User'
},
agente_assegnato_5: {
type: Schema.ObjectId,
ref: 'User'
},
agente_assegnato_jolly: {
type: Schema.ObjectId,
ref: 'User'
},
titolo_rif: String,
cognome_rif: String,
nome_rif: String,
cellulare_rif: String,
email_rif: String,
telefono_rif: String,
luoghi_consegna_sedi:{
type: [Schema.ObjectId],
ref: 'LuoghiConsegnaSede'
},
eliminato: {
type: Boolean,
default: false
},
created: {
type: Date,
default: Date.now
}
});
SedeSchema.set('toJSON', {getters: true});
mongoose.model('Sede', SedeSchema);
Luoghi_consegna_sedi
var mongoose = require('mongoose'),
Schema = mongoose.Schema;
var LuoghiConsegnaSedeSchema = new Schema({
titolo_rif: String,
cognome: String,
nome: String,
tipo_sede_consegna: String,
sede_consegna: String,
telefono_1: String,
telefono_2: String,
cellulare_rif: String,
email_rif: String,
telefono_rif: String,
tipo_indirizzo_consegna: String,
indirizzo_consegna: String,
n_civico_consegna: String,
piano_consegna: String,
interno_consegna: String,
scala_consegna: String,
citofonare_consegna: String,
citta_consegna: String,
provincia_consegna: String,
regione_consegna: String,
cap_consegna: String,
paese_consegna: String,
eliminato: {
type: Boolean,
default: false
},
created: {
type: Date,
default: Date.now
}
});
LuoghiConsegnaSedeSchema.set('toJSON', {getters: true});
mongoose.model('LuoghiConsegnaSede', LuoghiConsegnaSedeSchema);
答案 0 :(得分:3)
您的问题是将refs保存到其他文档中。
cliente.sedi = [];
for(var key in req.body.sede){
var sede = new Sede(req.body.sede[key]);
var luoghi_consegna_sedi = [];
for(jey in req.body.sede[key].lcs){
var luogo_consegna_sede = new LuoghiConsegnaSede(req.body.sede[key].lcs[jey]);
// save luogo_consegna_sede and then push its _id
luogo_consegna_sede.save();
luoghi_consegna_sedi.push(luogo_consegna_sede._id);
}
sede.luoghi_consegna_sedi = luoghi_consegna_sedi;
// Save sede and then push its id
sede.save();
cliente.sedi.push(sede._id);
}
cliente.save(function(err){
if(err)
return res.sendStatus(400);
return res.json(cliente);
});