MongoDB在3.2以上的版本有类似于 join 的 $lookup 聚合操作符,其实 Mongoose 有一个更强大的替代方法,叫做populate ( ),它允许你在其他集合中引用文档,实现更简洁优雅的查询操作...业务需求如下:查询文章信息,并显示文章的分类以及文章的作者信息,下面用 populate 来实现这个查询需求。 1....定义文章的 schema 生成模型导出,文件名 article.js 通过给 schema 中的关联字段添加 ref 与指定的模型建立关联 // 引入自定义的数据库连接文件 var mongoose =...执行查询操作 // 注意使用 populate 需要引入用到的 model var ArticleCateModel=require('....(err,docs){ console.log(docs); }) 通过给 populate 中传入所关联的字段与指定的集合进行关联查询,在 exec( ) 的回调方法中获取查询的结果。
本文源自工作中的一个问题,在使用 Mongoose 做关联查询时发现使用 populate() 方法不能直接关联非 _id 之外的其它字段,在网上搜索时这块的解决方案也并不是很多,在经过一番查阅、测试之后...图片来源:mongoing[1] 引用模型示例 JSON 模型 我们通过作者和书籍的关系,一个作者对应多个书籍这样一个简单的示例来学习如何在 MongoDB 中实现关联非 _id 查询。...如果需要指定哪些字段返回,哪些需要过滤,可定义 $project 对象,关联查询的字段过滤可使用 别名.关联文档中的字段 进行指定。...populate 做关联查询。...另外一种是 Mongoose 提供的 populate 方法,这种方式写起来,代码会更简洁些,这里需要注意如果关联的字段是非 _id 字段,一定要在 Schema 中设置虚拟值填充,否则 populate
({name:'森林'})对比相关操作符符号描述eq与指定的值相等ne与指定的值不相等gt大于指定的值gte大于等于指定的值lt小于指定的值lte小于等于指定的值in与查询数组中指定的值中的任何一个匹配...看完Models,最后让我们来看下在实战中比较有用的Populate 联表(Populate) Mongoose 的 populate() 可以连表查询,即在另外的集合中引用其文档。...Populate() 可以自动替换 document 中的指定字段,替换内容从其他 collection 中获取。...ref 选项告诉 Mongoose 在使用 populate() 填充的时候使用哪个 Model。...ref 选项告诉 Mongoose 在填充的时候使用 User model。所有储存在 answerer 中的 _id 都必须是 User model 中 document 的 _id。
console.log(err[attr]['message']); } }) 6、集合关联及实现 通常不同集合的数据之间是有关系的,例如文章信息和用户信息存储在不同集合中,...但文章是某个用户发表的,要查询文章的所有信息包括发表用户,就需要用到集合关联。...使用id对集合进行关联 使用populate方法进行关联集合查询 集合关联实现 // 用户集合 const User = mongoose.model('User', new mongoose.Schema...title: { type: String }, // 使用ID将文章集合和作者集合进行关联 author: { type: mongoose.Schema.Types.ObjectId..., ref: 'User' } })); //联合查询 Post.find() .populate('author') .then((err, result) => console.log
你也可以设定虚拟值的 setter ,下例中,当你赋值到虚拟值时,它可以自动拆分到其他属性: personSchema.virtual('fullName')....:布尔值 是否对这个属性创建索引 unique:布尔值 是否对这个属性创建唯一索引 sparse:布尔值 是否对这个属性创建稀疏索引 四、Connections-连接 可以使用 mongoose.connect...Model的多个静态辅助方法都可以查询文档 Query实例有一个.then()函数,用法类似Promise 我们看一下demo,查询persons表中name中属性last为Ghost值的文档,只查询...demo MongoDb 在 3.2之后,也有像 sql 中的 join 聚合操作,那就死$lookup,而 mongoose 拥有更强大的 populate,可以让你在别的 collection...Populate 可以自动替换 document 中的指定字段,替换内容从其他 collection 获取,我们填充(populate)单个或者多个 document、单个或者多个对象,甚至是 query
如果您想知道如何在表中查找重复值,那么您可以在 SQL 中使用 GROUP BY 和 HAVING 子句。 使用 group by 您可以创建组,如果您的组有超过 1 个元素,则意味着它是重复的。...您需要编写一个查询来查找所有重复值。...: +---------+ | Email | +---------+ | a@b.com | +---------+ 用于查找列中重复值的 SQL 查询 在 SQL 查询中解决这个问题的三种方法,...这是查找重复电子邮件的 SQL 查询: SELECT Email FROM Person GROUP BY Email HAVING COUNT(Email) > 1 使用self-join在列中查找重复值...= b.Id 使用带有 EXISTS 的子查询查找重复的电子邮件: 您甚至可以使用相关子查询来解决这个问题。 在相关子查询中,对外部查询中的每条记录执行内部查询。
实际在数据库中产生的集合名为courses 2.创建文档 创建文档实际上就是向集合中插入数据。 方法1 分为两步: ①创建集合实例。 ②调用实例对象下的save方法将数据保存到数据库中。...}, {要修改的值}).then(result => console.log(result)) // 更新多个 User.updateMany({查询条件}, {要更改的值}).then(result...} } }); // 使用规则创建集合 const Post = mongoose.model('Post', postSchema); // create方法插入数据 Post.create...使用id对集合进行关联 使用populate方法进行关联集合查询 ?...type: String }, // 1、使用ID将文章集合和作者集合进行关联 author: { type: mongoose.Schema.Types.ObjectId
/user.json(导入文件) 查询文档 // 引入mongoose第三方模块 用来操作数据库 const mongoose = require('mongoose'); // 数据库连接 mongoose.connect...const User = mongoose.model('User', userSchema); // 查询用户集合中的所有文档 User.find().then(result => console.log...({age: {$gt: 20, $lt: 40}}).then(result => console.log(result)) // 查询用户集合中hobbies字段值包含足球的文档 // User.find...User = mongoose.model('User', userSchema); // 查找到一条文档并且删除 // 返回删除的文档 // 如何查询条件匹配了多个文档 那么将会删除第一个匹配的文档...// true 验证成功 // false 验证失败 // v 要验证的值 return v && v.length > 4 }, // 自定义错误信息 message: '传入的值不符合验证规则
直接上代码: var mongoose = require('mongoose'); var Schema = mongoose.Schema; var async = require('async')...$page = { pageNumber: page }; async.parallel({ count: function (done) { // 查询数量...done(err, count); }); }, records: function (done) { // 查询一页的记录...Model.find(queryParams).skip(start).limit(pageSize).populate(populate).sort(sortParams)....results.records; callback(err, $page); }); }; module.exports = { pageQuery: pageQuery }; 使用方法
使用 Mongoose 简单的建立一个博客数据库以及模型之间的关联。...categories: [ // 分类与分类模型相关联 6 { 7 type: mongoose.SchemaTypes.ObjectId, // 关联分类模型中的唯一 _id...populate()可以跟踪关联的_id,输出详细的内容。...因为分类模型中不存在对 Post 的记录所以查询的时候要建立虚拟字段。...("Category", CategorySchema); COPY 修改之后直接就可以查询到了。
两个Schema: User:用户 Article:文章 其中一个用户可以包含多个文章 使用mongoose 在关系型数据库中,我们通常将这两个对象设计成一对多的关系,一个User对应多个Article...而使用mongoose我们可以如此设计: User: { username: {type: String, required: true, unique: true},// 用户名 password...default: Date.now}, _user: { type: Schema.Types.ObjectId, ref: 'User' } } Article中的..._user字段是关键,使用ref,将其与User关联,那么使用mongoose查询Article时(populate方法),就会将其关联的User一并查出。..._user.username); }) 关键字: populate
通过查找资料我的总结如下: 如果只需要通过A集合查询B集合,而不需要反过来查询,也就是单向的关系(如文章和评论,只需要展示文章的时候,将其评论展示即可),那么可以在A集合中建立一个子集合B。...如果既需要通过A查询B,又需要通过B查询A(如作者和文章,需要查询某作者下的所有文章,展示文章的时候,有需要展示作者的相关信息),那么可以在子集合中通过一个唯一字段关联父集合。..._user.username是出不来数据的,原因就是我们需要用到populate()函数。...var article = Article.findById(id, callback).populate('_user'); 这样article._user.username就有数据了。...以前使用Hibernate,默认是没有这个功能的,要想实现需要通过@PrePersist注解和@PreUpdate注解来手动定义好,很是麻烦。
准备工作 let mongoose = require("mongoose"); let connection = require("....8 9 10 sort 指定排序的字段和升序还是降序 1,-1 skip 指定跳过几条,忽略几条 limit 限定返回的最大条数 更新 update有两个参数,第一个参数是条件,第二个参数是更新后的值...使用了一个ref的类型是引用的User模型 (async function(scoreId){ let score = await Score.findById(scoreId).populate...('uid'); console.log(score); })("5f22712e78f5d73c7cae4b2f") image.png 上图使用了populate是填充的意思 就是把一个外键字段...从一个ObjectId变成另外一个字段来实现联表查询。
}, {要修改的值}).then(result => console.log(result)) // 更新多个 User.updateMany({查询条件}, {要更改的值}).then(result...} } }); // 使用规则创建集合 const Post = mongoose.model('Post', postSchema); // create方法插入数据 Post.create...使用id对集合进行关联 使用populate方法进行关联集合查询 // 关联集合 const mongoose = require('mongoose'); // 连接数据库 mongoose.connect...type: String }, // 1、使用ID将文章集合和作者集合进行关联 author: { type: mongoose.Schema.Types.ObjectId...案例:用户信息增删改查 搭建网站服务器,实现客户端与服务器端的通信 连接数据库,创建用户集合,向集合中插入文档 当用户访问/list时, 将所有用户信息查询出来 将用户信息和表格HTML
---- 更新记录:2018-4-9,md5加密 win10安装mongodb window下安装mongodb,需要参考的可以移步我的博客中:win10安装mongodb 项目初始化 本次项目使用的是...如下图是我的student集合: 在该集合中,学生参加过的考试记录,存在exams数组中,当想实现分页查询几条数据的时候,需要用到$slice $slice:[start,size] 第一个参数表示...({path:'_questions'}).exec((err1,doc1)=>{ .... }) }; 还有一种模糊分页查询–查询关联文档再模糊分页查询 先通过populate...mongodb本来就是非关系型的数据库,但是有很多时候不同的集合直接是需要关联的,这是就用到了mongoose提供的populate 直接看图,不同集合直接的关联,用的就是_id,比如下图中,学生参加的考试...,关联了试卷,试卷里面又关联了题目 怎么查询呢: Student.findOne({}).populate({path:'exams.
评论应该是在整个博客数据存储中,模型最为复杂的一部分了。首先要考虑的是和文章进行关联。这个可以用 mongoDB 的 ref 进行关联,随后可以使用 populate 计算出被关联的字段。...查询的时候如何去由根到叶顺序输出层级关系。...在后期处理回复路由的时候不要忘记修改他的值。最关键的是 key 列,这个用来记录平行层级。...如 post 中的一篇 pid 为 11 的文章下有一条评论,那么 key 中命名 11#001,这是第一条评论,如果该评论下存在一条回复,则回复的 key 为 11#001#001,下层亦是如此。...然后删除 key 为 11#001 的评论只要使用正则匹配 /^11#001/即可,把匹配到的内容全部删除就可以不用管关联的 post 是否一致,以及 cid,而 key 的值可以从前端发起的请求中提取
有这样两张表 addon_passwordbox_category 'use strict' var mongoose = require('mongoose'), Schema = mongoose.Schema...Schema.Types.ObjectId, ref: 'addon_passwordbox_category'}, // addon-passwordbox-category表中对应的类别的...Schema({ email: String, // addon-passwordbox-list表中的_id name: String, /...('addon_passwordbox_category', addon_passwordbox_category) addon_passwordbox_list 二张表使用catId作为主键关联 现在查...addon_passwordbox_list 表时要自动带出关联的addon_passwordbox_category表的数据 使用 populate() 代码如下: findAllByCondition
数据库的所有操作都是异步操作 1.使用create方法创建文档 通过回调函数的方法获取异步API // 向集合中插入文档 Course.create({ name: 'JavaScript',...使用id对集合进行关联 使用populate方法进行关联集合查询 ?...使用ID将文章集合和作者集合进行关联 author: { type: mongoose.Schema.Types.ObjectId, ref: 'User' } })); //联合查询 Post.find...,实现客户端与服务器端的通信 连接数据库,创建用户集合,向集合中插入文档 当用户访问/list时,将所有用户信息查询出来 实现路由功能 呈现用户列表页面 从数据库中查询用户信息...,并实现修改用户信息功能 修改用户信息分为两大步骤 1.增加页面路由 呈现页面 1.在点击修改按钮的时候 将用户ID传递到当前页面 2.从数据库中查询当前用户信息 将用户信息展示到页面中
最佳实践 请求设计规范 URI 使用名词,尽量使用复数,如/users URI 使用嵌套表示关联关系,如/users/123/repos/234 使用正确的 HTTP 方法,如 GET/POST/PUT...上面说了这么多,下面让我们看一下如何在 Koa 中践行RESTful API最佳实践吧。...Status,如 200/400 发送 Body,如{name: 'jack'} 发送 Header,如 Allow、Content-Type 编写控制器的最佳实践 每个资源的控制器放在不同的文件里 尽量使用类...简单的说,Mongoose就是对node环境中MongoDB数据库操作的封装,一个对象模型(ODM)工具,将数据库中的数据转换为JavaScript对象以供我们在应用中使用。...在这里主要是以用户模块的crud为例来展示下如何在 koa 中践行RESTful API最佳实践。
深入浅出mongodb(一)和深入浅出mongodb(二)两篇文章讲述了一些安装和使用的基础知识,这篇文章小编将带你走进实战世界,真正体会项目中是怎么使用mongodb开发,让我们一起揭开它神秘的面纱。...useUnifiedTopology: true }); 设置跨域 在开发中,我们采用的都是前后端分离的状态,在本地的开发环境中我们无法避免的会遇到跨域[3]的情况,我们这里设置允许所有的源访问 app.use...实际上在真正的开发环境中,如果我们这么设置允许所有的的源都可以访问会有很多问题,我们可以使用cors[4]来代替它 当然如果在生产中我们采用nginx部署之后,就不存在跨域了?...const mongoose = require("mongoose"); const Scheme = mongoose.Schema; const ObjectId = mongoose.Types.ObjectId...查询物品及所属人员 localhost:3000/api/goose get ? 最后 本文结束,有什么问题和有错误的地方,欢迎大家的留言和评论,还有后续更新,下期更加精彩 ???
领取专属 10元无门槛券
手把手带您无忧上云