0
votes

I have states which are related to country using foreign key.While fetching states,i am not able to get related countries,but get a weird result.Following are my models

Country model var mongoose = require('mongoose'); var Schema=mongoose.Schema

var CountrySchema =Schema(
    {
        name:{type:String,required:true},
        code :{type:String},
        status: { type: Boolean, default:true }
    }
)


    module.exports = mongoose.model('Country', CountrySchema

)

State model

    var mongoose = require('mongoose');
var Schema=mongoose.Schema

var Country =require('../../models/location/country');



var StateSchema=Schema(
    {
        name:{type:String,required:true},
        code :{type:String},
        status: { type: Boolean, default:true },
        country: { type: Schema.ObjectId, ref: 'Country', required: true },
        country:[Country.schema]
    }
)

module.exports = mongoose.model('State', StateSchema)

my response is as follows

{
    "data": {
        "5a36f32fc6ac751b711e9b19": {
            "name": "Kerala",
            "code": "KL",
            "_id": "5a36f32fc6ac751b711e9b19",
            "__v": 0,
            "country": [
                {
                    "_bsontype": "ObjectID",
                    "id": {
                        "type": "Buffer",
                        "data": [
                            90,
                            47,
                            16,
                            175,
                            152,
                            157,
                            109,
                            20,
                            5,
                            111,
                            70,
                            142
                        ]
                    },
                    "status": true
                }
            ],
            "status": true
        }
    }
}

Why i get this type data for country instead of getting the correct data

1

1 Answers

0
votes

You are showing us the api response which could have other issues. I am answering your question purely on the mongoose layer. You will need to edit your StateSchema so the country is not defined twice. Then use $looup

const Schema = require('mongoose').Schema;
const mongoose = require('mongoose');

const CountrySchema = Schema({
    name: { type: String, required: true },
    code: { type: String },
    status: { type: Boolean, default: true }
});
const Country = mongoose.model('Country', CountrySchema, 'countries');

const StateSchema = Schema({
    name: { type: String, required: true },
    code: { type: String },
    status: { type: Boolean, default: true },
    country: { type: Schema.ObjectId, ref: 'Country', required: true }
});
const State = mongoose.model('State', StateSchema, 'states');

mongoose.connect('mongodb://localhost:27017/test');

mongoose.connection.once('open', async () => {
    console.log("Connected to db.");
    const australia = await Country.insertMany({
        name: 'Australia',
        code: 'AU',
        status: 'active'
    })

    await State.insertMany({
        name: 'New South Wales',
        code: 'NSW',
        status: 'active',
        country: australia[0]._id
    })

const join = await State.aggregate([
    {
        $lookup: {
            from: 'countries',
            localField: 'country',
            foreignField: '_id',
            as: 'country_docs'
        }
    }
    ]);
    console.log(JSON.stringify(join));
});

$lookup is only available in mongo > 3.2