中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mongoose中的嵌套怎么利用populate進行處理

發布時間:2020-12-22 15:34:14 來源:億速云 閱讀:311 作者:Leah 欄目:web開發

這篇文章給大家介紹mongoose中的嵌套怎么利用populate進行處理,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

定義modal

在模式中,我們需要使用Schema.ObjectId來表示要指向數據在mongodb數據庫中的_id。

學校

在學校的Schema中,colleges屬性是要包含的學院的_id屬性數組。

var SchoolSchema = new Schema({
 name: String,
 colleges: [{
 type: Schema.ObjectId,
 ref: 'College'
 }],
 createTime: {
 type: Date,
 default: Date.now()
 }
});
var School = mongoose.model('School', SchoolSchema);

學院

var CollegeSchema = new Schema({
 name: String,
 students: [{
 type: Schema.ObjectId,
 ref: 'Student'
 }],
 createTime: {
 type: Date,
 default: Date.now()
 }
});
var College = mongoose.model('College', CollegeSchema);

學生

var StudentSchema = new Schema({
 name: String,
 sex: String,
 age: Number,
 createTime: {
 type: Date,
 default: Date.now()
 }
});
var Student = mongoose.model('Student', StudentSchema);

查找

直接查找

查找學校并找到指向的學院

School
 .find()
 .populate('colleges', ['_id','name'])
 .exec((err, schools) => {
 if (err) {
 console.log(err)
 }
 console.log(schools)
 })

populate的第一個參數是學校表中需要指向學院表的屬性,即colleges;第二個參數為要在學院中查找的屬性。如果不填寫第二個參數,則默認全都查出。

這樣查找出的結果中,學院的學生屬性是該學院包含的學生的_id屬性。如果需要都查找出來需要使用嵌套populate。

嵌套

School
 .find()
 .populate({
 path: 'colleges',
 select: ['_id', 'name'],
 // model: 'College',
 populate: {
 path: 'students',
 select: ['_id', 'name']
 // model: 'Student'
 }
 })
 .sort({
 createTime: -1
 }).exec(function(err, schools) {
 if (err) {
 console.log(err)
 }
 });

關于mongoose中的嵌套怎么利用populate進行處理就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

施秉县| 七台河市| 甘德县| 工布江达县| 龙里县| 西乡县| 镇宁| 黎平县| 道孚县| 碌曲县| 绥德县| 和龙市| 淮南市| 辉县市| 科尔| 噶尔县| 惠东县| 监利县| 彭山县| 崇义县| 腾冲县| 巢湖市| 宜都市| 宁远县| 海原县| 浑源县| 柘荣县| 綦江县| 永宁县| 合水县| 德化县| 渑池县| 乌海市| 改则县| 赤水市| 宜黄县| 江都市| 阿拉善左旗| 神农架林区| 沙雅县| 天镇县|