Mongoose 多表(N个表)关联查询aggregate
Mongoose 多表(N个表)关联查询概述
需求:文章(article),文章分类(articlecate),用户(user)这三个表之间的关系,一篇文章对应文章分类表中的某个类型,对应着用户表中的某个用户

Mongoose 多表(N个表)关联查询代码实现
首先我们需要创建db.js(连接数据库)的模块
var mongoose = require('mongoose');
mongoose.connect('mongodb://127.0.0.1:27017/eggcms',{ useNewUrlParser: true },function(err){
if(err){
console.log(err);
return;
}
console.log('数据库连接成功')
});
module.exports = mongoose;
通过上面的需求我们需要建立三个model模块分别是article.js,articlecate.js,user.js
var mongoose = require('./db.js');
var Schema = mongoose.Schema;
var ArticleSchema = new Schema({
title: {
type: String,
unique: true
},
cid: { // 分类id
type: Schema.Types.ObjectId
},
author_id:{ // 用户的id
type: Schema.Types.ObjectId
},
author_name:{
type:String
},
descripton: String,
content: String
});
module.exports = mongoose.model('Article',ArticleSchema,'article');
var mongoose = require('./db.js');
var ArticleCateSchema = new mongoose.Schema({
title : {
type: String,
unique: true
},
descripton: String,
addtime: {
type: Date
}
});
module.exports = mongoose.model('ArticleCate',ArticleCateSchema,'articlecate');
var mongoose = require('./db.js');
var UserSchema = new mongoose.Schema({
username: {
type: String,
unique: true
},
password: String,
name: String,
age: Number,
sex: String,
tel: Number,
status: {
type: Number,
default: 1
}
});
module.exports = mongoose.model('User',UserSchema,'user');
然后分别对应三个添加数据的模块article_add.js,articlecate_add.js,user_add.js
var ArticleModel = require('./model/article.js');
var article = new ArticleModel();
article.title="这是一个国际新闻333333333"
article.cid='5cde87e21ebf22597c973f1f'; // 分类id
article.author_id='5cde88f71faa8045e439838b'; // 用户id
article.author_name='李四';
article.descripton='这是一个国际新闻333333333333 此处省略300字';
article.content='访问美国 这是一个国际新闻333333333'
article.save();
var ArticleCateModel = require('./model/articlecate.js');
// 分类的增加
var cate = new ArticleCateModel({
title:'地方新闻',
description:'地方新闻'
})
cate.save();
var UserModel = require('./model/user.js');
// 增加用户
var user= new UserModel({
username :'wangwu',
password:'qwerqwerqewrq',
name:'王五',
age:21,
sex:'男',
tel:12345678987
})
user.save();

当我们添加了一些数据之后再app.js中进行数据库查询的操作
查询文章信息
var ArticleModel = require('./model/article.js')
// 查询文章信息
ArticleModel.find({}, (err,docs) => {
console.log(docs)
})

两个表关联查询
var ArticleModel = require('./model/article.js');
//两个表关联查询
ArticleModel.aggregate([
{
$lookup: {
from: "articlecate",
localField: "cid",
foreignField: "_id",
as: "cate"
}
}
],function(err,docs){
console.log(JSON.stringify(docs))
})

将其转成正常的JSON便于查看效果

多表关联查询
查询文章信息 并显示文章的分类 以及文章的作者信息
var ArticleModel = require('./model/article.js');
// 查询文章信息 并显示文章的分类 以及文章的作者信息
// 三个表关联查询
ArticleModel.aggregate([
{
$lookup: {
from: "articlecate",
localField: "cid",
foreignField: "_id",
as: "cate"
}
},
{
$lookup: {
from: "user",
localField: "author_id",
foreignField: "_id",
as: "user"
}
}
],function(err,docs){
console.log(JSON.stringify(docs));
})

将其转成正常的JSON便于查看效果
[{
"_id": "5cde89b2ecdd5e4864bdaa44",
"title": "这是一个国内新闻11111111",
"cid": "5cde87ce5ac6d7551041c568",
"author_id": "5cde8913a0e31553449bdf54",
"author_name": "王五",
"descripton": "这是一个国内新闻11111111 此处省略300字",
"content": "访问美国 这是一个国内新闻11111111",
"__v": 0,
"cate": [{
"_id": "5cde87ce5ac6d7551041c568",
"title": "国内新闻",
"__v": 0
}],
"user": [{
"_id": "5cde8913a0e31553449bdf54",
"status": 1,
"username": "wangwu",
"password": "qwerqwerqewrq",
"name": "王五",
"age": 21,
"sex": "男",
"tel": 12345678987,
"__v": 0
}]
}, {
"_id": "5cde89dc0d116f45fca7f559",
"title": "这是一个国际新闻222222222222",
"cid": "5cde87e21ebf22597c973f1f",
"author_id": "5cde8913a0e31553449bdf54",
"author_name": "王五",
"descripton": "这是一个国际新闻222222222222 此处省略300字",
"content": "访问美国 这是一个国际新闻222222222222",
"__v": 0,
"cate": [{
"_id": "5cde87e21ebf22597c973f1f",
"title": "国际新闻",
"__v": 0
}],
"user": [{
"_id": "5cde8913a0e31553449bdf54",
"status": 1,
"username": "wangwu",
"password": "qwerqwerqewrq",
"name": "王五",
"age": 21,
"sex": "男",
"tel": 12345678987,
"__v": 0
}]
}, {
"_id": "5cde8a078a1ab250f4dbb8e0",
"title": "这是一个国际新闻333333333",
"cid": "5cde87e21ebf22597c973f1f",
"author_id": "5cde88f71faa8045e439838b",
"author_name": "李四",
"descripton": "这是一个国际新闻333333333333 此处省略300字",
"content": "访问美国 这是一个国际新闻333333333",
"__v": 0,
"cate": [{
"_id": "5cde87e21ebf22597c973f1f",
"title": "国际新闻",
"__v": 0
}],
"user": [{
"_id": "5cde88f71faa8045e439838b",
"status": 1,
"username": "lisi",
"password": "13214lkisisgfdsgsdsg",
"name": "李四",
"age": 20,
"sex": "男",
"tel": 124212142151,
"__v": 0
}]
}]
Mongoose 多表(N个表)关联查询aggregate的更多相关文章
- Mongoose 两个表关联查询aggregate 以及 Mongoose中获取ObjectId
Mongoose 两个表关联查询aggregate 通常两个表关联查询的时候,是一种一对多的关系,比如订单与订单详情就是一对多的关系,一个订单下面有多个商品 数据模拟 首先我们先将数据模拟出来,先选择 ...
- sql关联查询—将一个表的查询结果作为新表进行查询操作
例题:# 各个部门中 最高工资中最低的那个部门的 最低工资是多少? 先考虑取得各个部门最高工资 SELECT MAX(salary) AS max_salary,e.`department_id` ...
- Mongoose中关联查询populate的使用
MongoDB中没有join的特性,因此无法使用join进行表的连接和关联查询,在Mongoose中封装了populate方法,在定义一个 Schema 的时候可以指定了其中的字段(属性)是另一个Sc ...
- SQL语句关联查询
一:连接类型: 关联查询:只有存在关联的表才能关联查询,完全独立的表之间无法关联 1.关联的类型:自关联,左关联,右关联,全关联(full join)两张表都是主表 2.关联的表:两张以上,以一张(或 ...
- JDBC MySQL 多表关联查询查询
public static void main(String[] args) throws Exception{ Class.forName("com.mysql.jdbc.Driver&q ...
- C#代码中实现两个表(DataTable)的关联查询(JOIN)
之前通常都是使用SQL直接从数据库中取出表1和表2关联查询后的数据,只需要用一个JOIN就可以了,非常方便.近日遇到一种情况,两个表中的数据已经取到代码中,需要在代码中将这两个表关联起来,并得到它们横 ...
- Spring+MyBatis框架中sql语句的书写,数据集的传递以及多表关联查询
在很多Java EE项目中,Spring+MyBatis框架经常被用到,项目搭建在这里不再赘述,现在要将的是如何在项目中书写,增删改查的语句,如何操作数据库,以及后台如何获取数据,如何进行关联查询,以 ...
- Yii2中多表关联查询(join、joinwith)
我们用实例来说明这一部分 表结构 现在有客户表.订单表.图书表.作者表, 客户表Customer (id customer_name) 订单表Order (id order_name ...
- MSSQL N张表关联查询
declare @newTime varchar(50); declare @lasetTime varchar(50); set @newTime= getdate(); set @lasetTim ...
随机推荐
- MySQL之查询篇(三)
一:查询 1.创建数据库,数据表 -- 创建数据库 create database python_test_1 charset=utf8; -- 使用数据库 use python_test_1; -- ...
- 【开发笔记】-通过js控制input禁止输入空格
<input type="text" id="fname" onkeyup="myFunction(id)"> <scri ...
- android启动时间慢的问题
[转]对于Android的性能这方面评估,大部分都是有超级兔子去比跑分的,还是不能反映全面的问题.就我知道的而言,应用启动时间是很影响用户体验的一个性能方面问题. 最近的一个项目,别人都说应用启动慢 ...
- linux配置iptables
iptables主要用来配置防火墙.其是一个需要特别谨慎设置的东西,服务器不在身边,不要贸然设置,有可能导致无法SSH,那就麻烦了. 1.首先介绍一下指令和相关配置文件 启动指令:service ip ...
- vim巧妙用法
1. 块复制 按ctrl+v键,编辑框最下方将出现"可视 块"字样 使用方向键移动光标,选择矩形区域内的文字 y 键复制文本: d 键剪切文本:p 键粘贴文本 按shift+v键, ...
- Python之路(第四十四篇)线程同步锁、死锁、递归锁、信号量
在使用多线程的应用下,如何保证线程安全,以及线程之间的同步,或者访问共享变量等问题是十分棘手的问题,也是使用多线程下面临的问题,如果处理不好,会带来较严重的后果,使用python多线程中提供Lock ...
- Ajax跨域问题及解决方案 asp.net core 系列之允许跨越访问(Enable Cross-Origin Requests:CORS) c#中的Cache缓存技术 C#中的Cookie C#串口扫描枪的简单实现 c#Socket服务器与客户端的开发(2)
Ajax跨域问题及解决方案 目录 复现Ajax跨域问题 Ajax跨域介绍 Ajax跨域解决方案 一. 在服务端添加响应头Access-Control-Allow-Origin 二. 使用JSONP ...
- Linux运维技术之scp命令使用
命令格式: scp -P 8031 -r 路径1 路径2 命令解释, 其中-P中的P一定要大写,小写不行(这个也是问题的关键,这个大小写耽搁了好长时间) -P 2424表示更改SSH端口后的端口,如 ...
- 离线安装python的ibm_db模块
目前手头的项目是一个UI自动化框架,其中有些模块的功能需要与DB2数据库交互,于是百度了一下python操作DB2的模块是 ibm_db. 然而我的工作机器是一台windows堡垒机,不能联网,固不能 ...
- CentOS 7.2搭建FastDFS 分布式文件系统,实现高可用集群
分布式集群搭建结构 双Tracker 2组Group 轮询存储策略 Keepalived+Nginx高可用 Nginx缓存 4个存储节点 一. 集群规划清单 1.安装清单 软件名称 版本 百度云盘存放 ...