首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Mongoose 实现关联查询和踩坑记录

本文源自工作中的一个问题,在使用 Mongoose 做关联查询时发现使用 populate() 方法不能直接关联非 _id 之外的其它字段,在网上搜索时这块的解决方案也并不是很多,在经过一番查阅、测试之后...文档内嵌与引用模式 MongoDB 是一种文档对象模型,使用起来很灵活,它的文档结构分为 内嵌和引用 两种类型。...Virtual 和 populate 实现 Mongoose 的 populate 方法默认情况下是指向的要关联的集合的 _id 字段,并且在 populate 方法里无法更改的,但是在 Mongoose...另外一种是 Mongoose 提供的 populate 方法,这种方式写起来,代码会更简洁些,这里需要注意如果关联的字段是非 _id 字段,一定要在 Schema 中设置虚拟值填充,否则 populate.../mongoose-populate - END -

26.5K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    使用Mongoose的populate方法实现多表关联查询

    MongoDB在3.2以上的版本有类似于 join 的 $lookup 聚合操作符,其实 Mongoose 有一个更强大的替代方法,叫做populate ( ),它允许你在其他集合中引用文档,实现更简洁优雅的查询操作...业务需求如下:查询文章信息,并显示文章的分类以及文章的作者信息,下面用 populate 来实现这个查询需求。 1....执行查询操作 // 注意使用 populate 需要引入用到的 model var ArticleCateModel=require('....(docs); }) // 文章表、分类表、用户表关联 ArticleModel.find({}).populate('cid').populate('author_id').exec(function...(err,docs){ console.log(docs); }) 通过给 populate 中传入所关联的字段与指定的集合进行关联查询,在 exec( ) 的回调方法中获取查询的结果。

    3.7K20

    在线考试系统(vue2 + elementui + express4 + MongoDB)

    初始化一条数据 如果对mongodb,mongoose没有基础的了解,建议看一看mongoose深入浅出 ,mongoose基础操作 // controllers/student.js const.../model/student'); var mongoose = require('mongoose'); var Schema = mongoose.Schema; var student = new...mongodb本来就是非关系型的数据库,但是有很多时候不同的集合直接是需要关联的,这是就用到了mongoose提供的populate 直接看图,不同集合直接的关联,用的就是_id,比如下图中,学生参加的考试...怎么才能让试卷、教师、问题关联起来啊,ref存的是_id,然而这些新增的数据,是保存之后才有_id的。..._id); // 教师中添加该试卷的_id doc.save(); // 很重要 不save则没有数据 // 第三步

    8.9K40

    Koa入门(四)Koa 操作数据库

    它的意义是:适用关系型数据库的时候就使用关系型数据库,不适用的时候也没有必要非使用关系型数据库不可,可以考虑使用更加合适的数据存储。...而非关系型数据库以键值对 (key-value) 存储,它的结构不固定,每一条记录可以有不一样的键,每条记录可以根据需要增加一些自己的键值对,这样就不会局限于固定的结构,可以减少一些时间和空间的开销。...下载地址 4 Koa + Mongodb 操作 4.1 安装链接 npm i mongoose -Sconst mongoose = require('mongoose') // 默认 27017 端口...ctx.status = 204 }使用put方法注册路由router.put('/following/:my_id/:id', follow)使用 postman 请求后拉取列表 如果想获取关注者的详细信息使用 populate...await User.find({ name: new RegExp(q) // 模糊搜索 }).limit(limit).skip(page * limit).select(selectFields).populate

    3K40

    ​eggjs实战

    全部接口文档包括:http://localhost:7001/swagger-doc 有了它,可以很方便地在注释创建接口,不需要再创建路由了!...app.emit('error', err, this) const status = err.status || 500 // 生产环境时 500 错误的详细错误内容不返回给客户端...它的作用在于我们可以将一些常用的动作抽离在 helper.js 里面成为一个独立的函数,这样可以用 JavaScript 来写复杂的逻辑,避免逻辑分散各处。...= app.mongoose const UserSchema = new mongoose.Schema({ mobile: { type: String, unique: true, required...框架提供了统一的入口文件( app.js)进行启动过程自定义,这个文件返回一个 Boot 类,我们可以通过定义 Boot 类中的生命周期方法来执行启动应用过程中的初始化工作。

    3.1K20

    Node使用火焰图优化CPU爆涨

    因为使用的局限性不是Linux的我,第一步apt install linux-tools-common都安不上,如果还要跑在虚拟机什么的上面是不是太麻烦了,方案一卒。...出来的各种方案在我一一踩坑后全部以失败告终,其实也还有一些更简单的方案,例如直接接入alinode用阿里云的平台就好,一方面该项目没有接入阿里云,刚好用的node镜像又不是ali的,另一方面,如果可以在开发环境查出问题,不希望再通过上线去查问题...从completeMany这里破案了,这是mongoose中的一个方法,作用是将查询到的结果进行包装,使结果中的每一个文档成为mongoose文档,使之可以继续使用mongoose提供的方法。...options.populate) { // 看这里 重点重点! return !!options.lean === true ?...__noPromise = true; _this.model.populate(docs, pop, function(err, docs) { if (err) return callback

    2.7K40

    Koa2+MongoDB+JWT实战--Restful API最佳实践

    具体如下: Representational: 数据的表现形式(JSON、XML...) state: 当前状态或者数据 transfer: 数据传输 它描述了一个系统如何与另一个交流。...主要存放在服务器,相对安全 cookie:主要存放在客户端,并且不是很安全 sessionStorage:仅在当前会话下有效,关闭页面或浏览器后被清除 localstorage:除非被清除,否则永久保存 工作原理...这两者的组合没什么问题,不过 koa-multer 和 koa-route(注意不是 koa-router) 存在不兼容的问题。...安装 mongoose npm install mongoose -S 连接及配置 const mongoose = require("mongoose"); mongoose.connect(....join(" "); const user = await User.findById(ctx.params.id) .select(selectFields) .populate

    9.3K42

    Nodejs和Mongodb的连接器Mongoose

    简介 今天我们将学习Mongoose,什么是Mongoose呢,它于MongoDB又是什么关系呢,它可以用来做什么呢,介绍Mongoose之前,我们先简单了解一下MongoDB。...MongoDB是一个开源的NoSQL数据库,相比MySQL那样的关系型数据库,它更显得轻巧、灵活,非常适合在数据规模很大、事务性不强的场合下使用。...同时它也是一个对象数据库,没有表、行等概念,也没有固定的模式和结构,所有的数据以文档的形式存储(文档,就是一个关联数组式的对象,它的内部由属性组成,一个属性对应的值可能是一个数、字符串、日期、数组,甚至是一个嵌套的文档...MongoDB —— 是一个对象数据库,没有表、行等概念,也没有固定的模式和结构,所有的数据以Document(以下简称文档)的形式存储(Document,就是一个关联数组式的对象,它的内部由属性组成,...创建集合 基于前面的内容,接下来我们就开始学习对数据的具体操作了,下面是关于一些基础数据的定义,相信对于你来说已经不陌生了,请在仔细温习一遍吧!

    5.9K41

    在Express中对MongoDB数据库进行增删改查

    编码前的准备工作 首先要安装好NodeJs运行环境,配置好node和npm的环境变量,最好安装淘宝 NPM 镜像cnpm,安装配置好npm后,打开终端运行npm install -g cnpm --registry...,简单易用,下面的代码演示了如何使用Express在指定的4001端口上监听,开启一个http服务,当然端口可以随意指定,只要和系统中其他不冲突即可,感觉使用起来比Java SpringBoot简单不少...mongoose') mongoose.connect('mongodb://localhost:27017/express-test', { useNewUrlParser: true,...req,res){ const product = await Product.findById(req.params.id); // 将客户端传过来的title赋值给产品(赋值不需要异步,因为它只是...req,res){ const product = await Product.findById(req.params.id); // 将客户端传过来的title赋值给产品(赋值不需要异步,因为它只是

    5.3K10

    Node.js 搭建一个 API 接口服务(实战)

    言归正传,Node.js是一个运行在服务端的框架,它底层使用的是V8引擎,它的速度非常快,并且作为一个前端的后端服务语言,还有其他吸引人的地方: 异步I/O 事件驱动 单线程 跨平台 而且,最最最最重要的一点就是...上面两张图很清晰的展示了洋葱模型的工作流程,当然,具体的原理实现的话与本篇无关,就不在深入描述了,有兴趣的同学可以自己到网上搜一下哈。...不过这个项目除了使用mysql,也还有用到mongo,接下来看看mongodb怎么用 使用mongoose作为mongodb的中间件 // mongoose入口 import mongoose from...) => { log('Mongoose connection disconnected') }) export default mongoose // 定义表模型 import mongoose...// ... } } // ... } export default new AccLogRoute() 说到这边,不得不提一句哈,就是路由可以引入装饰器写法,这样能减少重复工作和提高效率

    8.5K31
    领券