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

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

本文源自工作中的一个问题,在使用 Mongoose 做关联查询时发现使用 populate() 方法不能直接关联非 _id 之外的其它字段,在网上搜索时这块的解决方案也并不是很多,在经过一番查阅、测试之后...引用模型是一种规范化的数据模型,通过主外键的方式来关联多个文档之间的引用关系,减少了数据的冗余,在使用这种数据模型中就要用到关联查询,也就是本文我们要讲解的重点。..._id 字段,并且在 populate 方法里无法更改的,但是在 Mongoose 4.5.0 之后增加了虚拟值填充[3],以便实现文档中更复杂的一些关系。...如果你需要填充的虚拟值的显示是在 JSON 序列化中输出,就需要设置 toJSON 属性,例如 console.log(JSON.stringify(res))。...可以在创建 Schema 时在第二个参数 options 中设置,也可以使用创建的 Schema 对象的 set 方法设置。

26.5K20

WPF:无法对元素“XXX”设置 Name 特性值“YYY”。“XXX”在元素“ZZZ”的范围内,在另一范围内定义它时,已注册了名称。

WPF:无法对元素“XXX”设置 Name 特性值“YYY”。“XXX”在元素“ZZZ”的范围内,在另一范围内定义它时,已注册了名称。...2020-04-03 06:44 最近在改一段 XAML 代码时,我发现无论如何给一个控件添加 Name 或者 x:Name 属性时都会出现编译错误:无法对元素“XXX”设置...“XXX”在元素“ZZZ”的范围内,在另一范围内定义它时,已注册了名称。 ---- 编译错误 编译时,出现错误: 无法对元素“XXX”设置 Name 特性值“YYY”。...至于以上 XAML 代码中我看到用的是 来写样式,是因为踩到了当控件用的另一个坑: 所有在控件的 XAML 中设置的 Content 属性都将被使用时覆盖。...: /// /// 在解决方案资源管理器中右击目标项目,然后依次单击 /// “添加引用”->“项目”->[浏览查找并选择此项目] /// ///

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

    Nodejs和Mongodb的连接器Mongoose

    安装 引用 前面我们已经认识了Mongoose,也了解了MongoDB,回顾一下:MongoDB是一个对象数据库,是用来存储数据的;Mongoose是封装了MongoDB操作的一个对象模型库,是用来操作这些数据的...引用mongoose:  var mongoose = require("mongoose"); 3....在MongoDB中,多个Document可以组成Collection(以下简称集合),多个集合又可以组成数据库。...文档 —— 是MongoDB的核心概念,是键值对的一个有序集,在JavaScript里文档被表示成对象。同时它也是MongoDB中数据的基本单元,非常类似于关系型数据库管理系统中的行,但更具表现力。...Schema简述 Schema —— 一种以文件形式存储的数据库模型骨架,无法直接通往数据库端,也就是说它不具备对数据库的操作能力,仅仅只是数据库模型在程序片段中的一种表现,可以说是数据属性模型(传统意义的表结构

    5.9K41

    初试MongoDB学习之Mongoose的使用

    Mongoose本质是一个对象文档模型(ODM)库, 他对Node原生的MongoDB模块进行了一部优化封装,并且提供了更多的功能。...Node原生的MongoDB驱动更容易 #使用Mongoose 下载安装mongoose模块 cnpm install mongoose --save 引用mongoose: var mongoose...}) #mongoose基本使用 #mongoose的几个新的对象 在MongoDB中,多个Document可以组成Collection(以下简称集合),多个集合又可以组成数据库。...文档 —— 是MongoDB的核心概念,是键值对的一个有序集,在JavaScript里文档被表示成对象。同时它也是MongoDB中数据的基本单元,非常类似于关系型数据库管理系统中的行,但更具表现力。...#创建model(集合) let personModel= mongoose.model('person', personSchema); person:数据库中的集合名称,当我们对其添加数据时如果person

    5.9K20

    Node.js中的MongoDB

    # mongoDB基本组成 数据库(database):数据库是一个仓库,在仓库中可以存放集合。...集合(collection):集合类似于数组,在集合中可以存放文档。 文档(document):文档数据库中的最小单位,我们存储和操作的内容都是文档。.../12.向name为Html5的文档中,添加一个新的核心课程 "微信小程序" //$push 用于向数组中添加一个新的元素 //$addToSet 向数组中添加一个新元素 , 如果数组中已经存在了该元素..., 有时候我们只需要一个文档中的部分数据, 这时候就得通过映射在查询时, 可以在第二个参数来设置查询的结果投影 db.section.find({}, {name: 1, _id: 0, wages:...监听MongoDB数据库的连接状态:在mongoose对象中,有一个属性叫做connection,该对象表示的就是数据库连接, 通过监视该对象的状态,可以来监听数据库的连接与断开 mongoose.connection.once

    5.3K40

    Week14-服务端选型:磨刀不如砍柴功

    该代码逻辑在 bin/www中,通过www代码我们直到,数据表同步功能在sync-alter中 #!...这里,讲师再次推荐了自己的一个课程,鉴于此次购买课程自己不是很满意,这里,我觉得自己补充mongoose的基础知识就够了,总结至:https://www.yuque.com/liugezhou/gofftg...课程中关于redis的其它内容依旧是给出实战课让自己去学习,其它的什么也没说,而我本地也是安装过redis的,但是不记得如何启动了,于是我的步骤是这么展开的: 第一步:首先看本地的redis是否已删除...以后访问接口,都在header中带上token。 优缺点 优点:不占用服务器内存、多进程,多服务器,不受影响、不受跨域限制 缺点:无法快速封禁登录的用户。...:表关联,有一些外键的设置,我发现之前的后端表中都没有对外键盘做一个级联操作,于是在回头查看一些表结构的时候,就不容易看出来一些表的关联关系,如果我们在新建表的时候就去设置外键表的关联,首先表结构一目了然

    2K30

    Node.js基于Express框架搭建一个简单的注册登录Web功能

    logout",routes); // 即为为路径 /logout 设置路由 app.use是一个中间件的用法,这里的routes看初始项目的那句代码,就是引用了routes文件夹下的index.js模块...我们通过Mongoose去创建一个“集合”并对其进行增删改查,就要用到它的三个属性:Schema(数据属性模型)、Model、Entity   这里简单介绍一下,更详细的用法可以自行查阅~ Schema...—— 一种以文件形式存储的数据库模型骨架,无法直接通往数据库端,也就是说它不具备对数据库的操作能力,仅仅只是数据库模型在程序片段中的一种表现,可以说是数据属性模型(传统意义的表结构),又或着是“集合”...然后在app.js中引用它并作初始设置: var session = require('express-session'); var app = express(); app.use(session(.../logout')(app); }; 在app.js模块中再引用一下就可以(routes目录下index.js是默认文件,所以可以省略index) require('.

    7.3K10

    mongoose食用姿势!

    什么是Mongoose? Mongoose库简而言之就是对node环境中MongoDB数据库操作的封装,一种对象模型工具,可以将数据库中的数据转换为JavaScript对象供我们使用。...require("mongoose"); mongoose官网 http://mongoosejs.com mongoose入门 简单看一下官网的hello world入门代码 //    引包,...并不需要引用mongodb这个包     var mongoose = require('mongoose');     //链接数据库,itatic是数据库名字     mongoose.connect...旺财","age":4}) //然后把这个wangcai这个类进行save方法后就存入数据库中 mongoose所有的操作不慎对数据库操作,所有的操作都是对类、实例进行的。...:Number} }) 定义静态方法 语法:db.model({"Student",shema名字}) 实例: //查找的静态方法(只能定义在model层) StudentSchema.statics.chazhao

    1.5K30

    MongoDB系列一: Replica Set 集群搭建实战

    随着内部产品业务的搭建,单机的mongo已经无法满足生产需求,对于单机迁移、损坏等问题,简单的单机数据备份已经无法满足,因为采用了集群方式来满足容灾以及数据快速恢复等功能,下面我就来讲讲如何搭建集群来避免这些问题...1,2两种方式, 在日后的篇章中将详细介绍两者的区别。...当前我们采用的是 Replica Set 搭建方式。这是官方教程,我们会跟着官方教程,以及对官方未说明的一些信息进行补充。...特性 优势 1.提供容错功能,在主节点故障时,复制节点代替主节点 2.数据的快速恢复 3.增加节点可提高读能力 4.快速横向扩展 劣势 1.所有写操作都从主节点进行,增加节点无法提高写能力 2.每个节点都是完整备份...1567683192236.jpg 发现我们并不能直接查看 原因是: mongodb默认是从主节点读写数据的。 我们对复制节点进行进行设置。

    4K41

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

    MongoDB在3.2以上的版本有类似于 join 的 $lookup 聚合操作符,其实 Mongoose 有一个更强大的替代方法,叫做populate ( ),它允许你在其他集合中引用文档,实现更简洁优雅的查询操作...定义文章的 schema 生成模型导出,文件名 article.js 通过给 schema 中的关联字段添加 ref 与指定的模型建立关联 // 引入自定义的数据库连接文件 var mongoose =...String, unique: true }, // 分类ID cid: { type: Schema.Types.ObjectId, // 引用文章分类的模型...populate('cid').populate('author_id').exec(function(err,docs){ console.log(docs); }) 通过给 populate 中传入所关联的字段与指定的集合进行关联查询...,在 exec( ) 的回调方法中获取查询的结果。

    3.7K20

    Mongoose学习参考文档

    1.2 准备工作 1.首先你必须安装MongoDB和NodeJS 2.在项目只能够创建一个数据库连接,如下: var mongoose = require('mongoose'); //引用...Schema——纯洁的数据库原型 1.1 什么是Schema 我理解Schema仅仅只是一断代码,他书写完成后程序依然无法使用,更无法通往数据库端 他仅仅只是数据库模型在程序片段中的一种表现,或者是数据属性模型...1.4 Schema.Types NodeJS中的基本数据类型都属于Schema.Type,另外Mongoose还定义了自己的类型 //举例: var ExampleSchema =...,这里对Query解读的并不完善,仅仅是自己的一点领悟而已。...,不是什么数据都能往数据库里丢或者显示到客户端的,数据的验证需要记住以下规则: 验证始终定义在SchemaType中 验证是一个内部中间件 验证是在一个Document被保存时默认启用的,除非你关闭验证

    24.2K90

    大数据技术之_22_MongoDB学习_MongoDB 的简介、下载、安装、启动、配置和关闭 + MongoDB 的基本操作 + Mongoose + 使用 java 对 MongoDB 增删改查

    ({num: {$lte: 10}}); // limit() 设置显示数据的上限 db.numbers.find().limit(10); // 在开发时,我们绝对不会执行不带条件的查询 db.numbers.find...); db.emp.find(); 3.7 文档中的关系 文档之间的关系: 一对一:在 MongoDB 中可以通过内嵌文档的形式来体现出一对一的关系。...在多的表中存放一的id。...//在查询时,可以在第二个参数的位置来设置查询结果的--即投影 db.emp.find({}, {ename: 1, _id: 0, sal: 1});  第四章 Mongoose 4.1 Mongoose...一旦创建好了 Model 对象,就会自动和数据库中对应的集合建立连接,以确保在应用更改时,集合已经创建并具有适当的索引,且设置了必须性和唯一性。

    17.8K30

    你真的了解mongoose吗?

    select: 布尔值 指定 query 的默认 projections validate: 函数,对属性添加验证函数。...定义一个具有给定名称的虚拟属性,该名称可以获取/设置这个路径 索引 你可以用 schema 类型选项声明 MongoDB 的索引。 index: 布尔值,是否在属性中定义一个索引。...unique: 布尔值,是否在属性中定义一个唯一索引。 sparse: 布尔值,是否在属性中定义一个稀疏索引。...看完Models,最后让我们来看下在实战中比较有用的Populate 联表(Populate) Mongoose 的 populate() 可以连表查询,即在另外的集合中引用其文档。...ref 选项告诉 Mongoose 在填充的时候使用 User model。所有储存在 answerer 中的 _id 都必须是 User model 中 document 的 _id。

    41.6K30

    架构和数据库

    配置环境变量 我的电脑 -> 右键属性 -> 高级系统设置 -> 环境变量 -> 系统环境变量 -> 找到 Path 双击Path -> 在弹窗内添加mongodb安装目录D:\Project\MongoDB...数据库(database) 数据库是一个仓库,在仓库中可以存放多个集合 集合(collection) 集合类似于数组,在集合中可以存放多个文档 文档(document) 数据库中的最小单位,存储和操作的内容都是文档...users 集合中插入文档 文档的内容包含用户名、密码、年龄、爱好、邮箱、是否删除 10 文档关系 一对一(one to one) 夫妻(一个丈夫对应一个妻子) 可以使用内嵌文档的方式体现 一对多(...库,对原生的模块进行了封装,提供了更多的功能 Mongoose 优势 官方地址:http://www.mongoosejs.net/ 可以为文档创建一个模式结构(Schema) 可以对模型中的对象/文档进行验证...err) { console.log(count); } }); Document 对象 Document 和集合中的文档一一对应,Document 是 Model 的实例 通过

    8010

    04_数据库

    配置环境变量 我的电脑 -> 右键属性 -> 高级系统设置 -> 环境变量 -> 系统环境变量 -> 找到 Path 双击Path -> 在弹窗内添加mongodb安装目录D:\Project\MongoDB...数据库(database) 数据库是一个仓库,在仓库中可以存放多个集合 集合(collection) 集合类似于数组,在集合中可以存放多个文档 文档(document) 数据库中的最小单位...users 集合中插入文档 文档的内容包含用户名、密码、年龄、爱好、邮箱、是否删除 10 文档关系 一对一(one to one) 夫妻(一个丈夫对应一个妻子) 可以使用内嵌文档的方式体现 一对多...(ODM)库,对原生的模块进行了封装,提供了更多的功能 Mongoose 优势 官方地址:http://www.mongoosejs.net/ 可以为文档创建一个模式结构(Schema) 可以对模型中的对象...err) { console.log(count); } }); Document 对象 Document 和集合中的文档一一对应,Document 是 Model 的实例 通过

    7010

    GraphQL 基础实践

    变量定义:在 GraphQL 中,声明一个变量使用符号开头,冒号后面紧跟着变量的传入类型。如果要使用变量,直接引用即可,例如上面的 movie 就可以改写成 movie(name: name)。...ID类型代表着一个独一无二的标识,ID 类型最终会被转化成String类型,但它必须是独一无二的,例如 mongodb 中的 _id 字段就可以设置为ID类型。...const mongoose = require('think-mongoose');module.exports = [mongoose(think.app)]; 接下来,在 adapter.js 中配置数据库连接...回忆前面的数据模型定义,里面的 movies 和 actors 字段是一组另一个集合中数据的引用,目的是方便建立电影和演员信息之间的关系以及维护,在 Resolver 运行之后,movies 和 actors...接下来引用到我们中间件的handle配置中,完美,大功告成,用 ThinkJS 搭建的 GraphQL 服务器就此告一段落,npm start 运行起来之后,用 GraphiQL “播放”一下你的请求体

    12.8K20

    从项目中由浅入深的学习koa 、mongodb(4)

    :解析router的中间件 mongoose :基于mongdodb的数据库框架,操作数据 nodemon:后台服务启动热更新 3.项目目录 ├── app...resFormat.js // 格式化返回值 │ ├── models // 表目录(数据模型) │ │ ├── course.js // 课程表...// 路由目录 │ └── api // 接口目录 │ │ ├── course_router.js // 课程相关接口...对象封装到单个对象中,每个请求都将创建一个 Context,通过ctx访问暴露的方法 ctx方法 request:请求主体;response:响应主体;ctx.cookies.get:获取cookie...fs 分割文件 7.mongoose主要API API 作用 Schema 数据模式,表结构的定义;每个schema会映射到mongodb中的一个collection,它不具备操作数据库的能力 model

    1.8K20
    领券