在类型为'Schema.Types.ObjectId'的nodejs中填充返回null

时间:2019-12-16 00:33:09

标签: node.js mongoose node-modules mongoose-schema mongoose-populate

我有一个架构,其属性为'paciente'和'seguroAfiliado',类型为:Schema.Types.ObjectId。

现在的结果:

[
    {
        "_id": "5da619b36aae5e7028fc27db",
        "paciente": "5de31abf4c430918a39a7490",
        "seguroAfiliado": "5d65da2f008b72055d17abfb",
        "fecha": "2019-10-01T03:00:00.000Z",
        "motivoConsulta": "dww",
        "__v": 0
    }
]

我需要这两个属性的名称,并在nodejs中填充句子。

app.get('/', [
    mdAutenticacion.verificaToken,
], (req, res, next) => {

    var desde = req.query.desde || 0;
    desde = Number(desde);

    CitaMedica.find({})
        .skip(desde)
        .populate('paciente', ''nombre)
        .populate('seguroAfiliado', 'nombre')
        .exec(
        (err, medicalAppointment) => {

        if ( err ) {
            return res.status(500).json({
                ok: false,
                mensaje: 'Error charging list',
                errors: err
            });
        };

        CitaMedica.count({}, (err, conteo) => {
            res.status(200).json(medicalAppointment);
        });
    });
});

尝试那些人,但没有成功。

SeguroAfiliado架构

var mongoose = require('mongoose');

var Schema = mongoose.Schema;

var seguroAfiliadoSchema = new Schema({
    nombre: {
        type: String,
        require: false
    },
    numeroPoliza: {
        type: String,
        require: false
    },
    rif: {
        type: String,
        require: false
    },
    personaContacto: {
        type: String,
        require: false
    }, 
    em: {
        type: String,
        require: false
    }, 
    telefono: {
        type: String,
        require: false
    },
    email: {
        type: String,
        require: false
    },
    status: {
        type: String,
        require: false
    },
    imgSeguroAfiliado: {
        type: String,
        require: false
    },
    pais: {
        type: String,
        require: false
    },
    baremo: {
        type: String,
        require: false
    },
    actoQuirurgico: {
        type: String,
        require: false
    },
}, { collection: 'seguroAfiliado' });

module.exports = mongoose.model( 'Seguro Afiliado', seguroAfiliadoSchema );

CitasMedicas架构

var mongoose = require('mongoose');

var Schema = mongoose.Schema;

var citasMedicasSchema = new Schema({
    doctorId: {
        type: String,
        require: false
    },
    safeName: {
        type: String,
        require: false
    },
    paciente: {
        type: Schema.Types.ObjectId,
        require: false
    },
    seguroAfiliado: {
        type: Schema.Types.ObjectId,
        require: false
    },
    fecha: {
        type: String,
        require: false
    },
    motivoConsulta: {
        type: String,
        require: false
    },
}, { collection: 'citasMedicas' });

module.exports = mongoose.model( 'Citas Médicas', citasMedicasSchema );

尝试的结果是:

[
    {
        "_id": "5da619b36aae5e7028fc27db",
        "paciente": null,
        "seguroAfiliado": null,
        "fecha": "2019-10-01T03:00:00.000Z",
        "motivoConsulta": "dww",
        "__v": 0
    }
]

1 个答案:

答案 0 :(得分:2)

您忘记了ref选项,该选项告诉Mongoose在填充期间要使用哪种模型。在您的情况下,CitasMedicas模式应类似于:

var citasMedicasSchema = new Schema({
  ...
  paciente: {
    type: Schema.Types.ObjectId,
    ref: "RefModel",
    require: false
  },
  seguroAfiliado: {
    type: Schema.Types.ObjectId,
    ref: "RefModel",
    require: false
  },
  ...
}...