本文实例讲述了MongoDB多表关联查询操作。分享给大家供大家参考,具体如下:
Mongoose的多表关联查询
首先,我们回忆一下,MySQL多表关联查询的语句:
student表:
calss表:
通过student的classId关联进行查询学生名称,班级的数据:
SELECT student.name,student.age,class.name FROM student,class WHERE student.classId = class.id
Mongoose多表联合查询(还是以众所周知的学生、班级作为实例)
· 表结构的定义(schemas目录下)
1. student表(student.js)
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
/*定义数据模式*/
var StudentSchema = new mongoose.Schema({
name: String,
calssId: {
type: Schema.Types.objectId,
ref: 'class'
},
age: Number,
number: Number,
meta: {
createAt: {
type: Date,
default: Date.now()
},
updateAt: {
type: Date,
default: Date.now()
}
}
/*更新时间的*/
});
module.exports = StudentSchema;
2. class表(class.js)
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
/*定义数据模式*/
var ClassSchema = new mongoose.Schema({
name: String,
meta: {
createAt: {
type: Date,
default: Date.now()
},
updateAt: {
type: Date,
default: Date.now()
}
}
/*更新时间的*/
});
module.exports = ClassSchema;
· 生成Model(model目录下)
1. student Model(student.js)
var mongoose = require('mongoose');
var StudentSchema = require('../schemas/student');
/*通过model编译模式为模型*/
var Student = mongoose.model('student', StudentSchema);
/*导出Student模型 模块*/
module.exports = Student;
2. class Model(class.js)
var mongoose = require('mongoose');
var ClassSchema = require('../schemas/class');
/*通过model编译模式为模型*/
var Class = mongoose.model('class', ClassSchema);
/*导出Class模型 模块*/
module.exports = Class;
· Model进行数据的查询操作
1. 将静态类的方法加到Model的编译中
StudentSchema.static = {
fetch: function(cb){
return this
.find({})
.sort('meta.updateAt') //按更新的时间排序
}
}
2. 将静态类方法加到Model中
StudentSchema.static('fetch', function(cb){
return this
.find({}, cb)
.sort('meta.updateAt')
})
3. 直接调用model的find()方法
查询的结果均为:
[
{
_id: '5a05222f583e5720b8660191',
name: '张三',
age: 18,
number: 11,
classId: '5a0036512b740f32e4371e66'
},
{
_id: '5a05222f583e5720b8660091',
name: '李四',
age: 19,
number: 11,
classId: '5a0036512b740f32e1371e66'
},
{
_id: '5a05222f583e5720b18660191',
name: '赵五',
age: 17,
number: 11,
classId: '5a0036512b7420f32e4371e66'
}
]
· 多表联合查询(学生对应班级)
StudentSchema.static = {
findStudentWithClass: function (cb) {
return this
.find({})
.populate('classId')//注意这是联合查询的关键
.sort('meta.updateAt')
.exec(cb)
}
}
查询结果:
[
{
_id: '5a05222f583e5720b8660191',
name: '张三',
age: 18,
number: 11,
classId: {
_id: '5a0036512b740f32e4371e66',
name: '一年1班'
}
},
{
_id: '5a05222f583e5720b8660091',
name: '李四',
age: 18,
number: 11,
classId: {
_id: '5a0036512b740f32e1371e66',
name: '二年2班'
}
},
{
_id: '5a05222f583e5720b18660191',
name: '赵五',
age: 18,
number: 11,
classId: {
_id: '5a0036512b7420f32e4371e66',
name: '一年2班'
}
}
]
· 由上面的实例可知,mongoose的多表联合查询的关键:
1. 数据模式结构定义需要利用关键字ref定义关联
var Schema = new mongoose.Schema({
field: {
type: mongoose.Schema.Type.ObjectId,
ref: 'model'
}
});
Schema.static = {
fetch: function(cb){
return this
.find({})
.populate('field')
.exec(cb)
}
}
var Model = mongoose.Model('model',Schema );
希望本文所述对大家MongoDB数据库程序设计有所帮助。
MongoDB,多表关联查询
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]

