【问题标题】:Mongoose doesn't save nested sub documentsMongoose 不保存嵌套的子文档
【发布时间】:2015-07-03 02:27:48
【问题描述】:

我需要将一些子文档保存在架构中,该架构是架构的子文档。 保存功能是这样的:

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);
});
};

问题是顶级父模式(客户端)保存在 mongoldb 上,而两种类型的子文档没有。在 cliente.sedi 中,数组填充了 sede objectid,但在 mongoldb 上,sede 表不存在(对于 luoghi_consegna_sedi 也是如此)。 如果我在将 sede 和 luoghi_consegna_sedi 推送到它们的数组之前手动保存它们,则会创建两个表并填充数据,但是如果我在 cliente.sedi 上运行 populate() 我会得到一个空数组。 3个模式是: 客户

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);

【问题讨论】:

  • 问题已更新。谢谢

标签: node.js mongodb mongoose subdocument


【解决方案1】:

您的问题是将参考文献保存到其他文档。

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);
});

【讨论】:

  • cliente.sedi 是 [Schema.ObjectId]。如果我做一个 var cliente 的控制台日志,我会看到 cliente.sedi 不存在,并且在 sede 中也没有 luoghi_consegna_sedi 字段,而是有 lcs(取自 req.body)。为什么我不能设置 luoghi_consegna_sedi 和 sedi 字段?
  • 我的猜测是错误的。 sedi 是否有自己的 Schema 和 cliente.sedi 对 Schema 的引用?
  • 是的。 sedi 是一个 objectid 数组,其 ref 为 sede(sedi 的模式名称)
  • @pindol 您必须致电cliente.markModified('sedi') 否则猫鼬不会推送更改。请参阅this,问题 1。
  • @Tony 好点,猫鼬不会为数组索引创建 getter/setter。但是,@pindol 会尝试保存新文档,因此在这种情况下不需要 markModified
猜你喜欢
  • 2018-06-30
  • 1970-01-01
  • 1970-01-01
  • 2016-04-25
  • 2017-08-30
  • 2014-04-07
  • 1970-01-01
  • 2014-11-09
  • 2021-03-26
相关资源
最近更新 更多