1.安装nest.js脚手架 cnpm i -g @nestjs/cli 2.创建nest项目 nest new 项目名 3.安装mongoose 项目中我们会用到 Mongoose 来操作我们的数据库...,Nest 官方为我们提供了一个 Mongoose 的封装,我们需要安装 mongoose 和 @nestjs/mongoose: npm install mongoose @nestjs/mongoose...执行上面的终端命令之后,app.module.ts 中的代码已经发生了变化,在文件顶部自动引入了 UserModule,同时也在 @Module 装饰器的 imports 中引入了 UserModule...根模块Mongoose 连接数据之前,我们要先在根模块,也就是 app.module.ts 中引入 Mongoose 的连接模块: // app.module.ts import { Module }...8.引入 分模块Mongoose 这里我们先要创建一个数据表的格式,在 src/server/user 文件夹下创建一个 user.schema.ts 文件,定义一个数据表的格式: // user.schema.ts
MongoDB 的索引有哪些 nestjs mongoose示例 复合索引(Compound Index): 索引多个字段,允许对这些字段的组合进行高效查询。...这可以提高对哈希键的查询性能,因为 MongoDB 不需要扫描整个集合来查找匹配的文档。...这允许基于地理位置进行高效的范围查询和最近邻搜索。...({ title: 'text', content: 'text' }); 唯一索引(Unique Index): 确保集合中每个文档的索引字段值都是唯一的。...}); 覆盖索引(Covering Index): 包含查询中所需的所有字段,从而避免额外的磁盘访问来检索数据。
在 NodeJS 的世界里,也存在一个全面借鉴 Spring 设计思想的框架,它在 github 上有将近 2w 的 star,npm 的周下载量超过 11w,它就是本文要介绍的 NestJS。...依赖注入最大的作用是代码解耦,依赖的对象根据不同的情况可以有多种实现,如单元测试的时候可以在不改业务代码的情况下将依赖的对象换成 Mock 数据。...DTO 的定义如下,也是通过注解定义校验逻辑: export class CreateCatDto { @IsString() readonly name: string; @IsNumber...连接数据库 例子中使用mongoose连接和操作本地MongoDB数据库。为了更方便使用,Nest提供了@nestjs/mongoose包,对mongoose包装了一层,使其更符合Nest的使用风格。...操作数据库的步骤如下: app.module中定义连接的数据库:MongooseModule.forRoot('mongodb://localhost/nest') cat.schema中定义 Schema
GraphQL 既是一种用于 API 的查询语言也是一个满足你数据查询的运行时。...GraphQL 对你的 API 中的数据提供了一套易于理解的完整描述,使得客户端能够准确地获得它需要的数据,而且没有任何冗余,也让 API 更容易地随着时间推移而演进,还能用于构建强大的开发者工具。...如getBlogAndAuthor,这样直接为调用方“定制”一个接口,请求一条就得到就调用方想要的数据。...请求进行查询,其集中的 API 如 http://localhost:3000/graphql,所有的操作都通过这个接口来执行,这会在后面的操作中在展示到。...中 hello 函数所定义的返回体。
Map 约束能用对象的方法描述数据类型 是否必须 是否重复 默认值 等,如下定义了一个用户表结构 注意:如果定义表结构时没有定义_id,mongoose会自己添加一个该字段,该字段不会重复,类型为ObjectId...(name,sechem)来创建表结构构造器,通过传入数据来实例化构造器获得具体的表 注意:在这一步的时候数据库已经有了表,表名全是小写且表明为name加上s,如这里会创建表users const User...= mongoose.model("User", userSechem); ---- 通过上面的操作就获得了表的构造函数,接下来就可以向里面进行增删改查了 增 有三种方法在表内增加数据: 通过实例化数据...: 创建表数据实例化model 通过传入具体的数据来实例化表,能获得一条具体的表数据,类型为Mongoose Documents,向数据库中查找到的也是这种类型数据 const user = new User...方法: 通过表构造器的静态方法create自动在表中插入新的数据 该方法可以接收多个插入数据,最后的回调函数参数根据数据量决定 该方法支持两种调用: 错误优先的回调 async await const
非关系型数据库的解决思路: 在文章的Collection中增加一个SubCollection,SubCollection中可以存放用户信息,如用户名,只要有用户喜欢了文章,在这篇文章的文档中的子文档下插入一条记录即可...通过查找资料我的总结如下: 如果只需要通过A集合查询B集合,而不需要反过来查询,也就是单向的关系(如文章和评论,只需要展示文章的时候,将其评论展示即可),那么可以在A集合中建立一个子集合B。...如果既需要通过A查询B,又需要通过B查询A(如作者和文章,需要查询某作者下的所有文章,展示文章的时候,有需要展示作者的相关信息),那么可以在子集合中通过一个唯一字段关联父集合。...在articleSchema中增加一个字段_user,类型为Schema.Types.ObjectId,关联User: _user: { type: Schema.Types.ObjectId,...而Mongoose的解决方法是在数据库的定义时就可以将这些信息定义好。这可能也就是约定优于配置(convention over configuration)的好处吧!
最佳实践 请求设计规范 URI 使用名词,尽量使用复数,如/users URI 使用嵌套表示关联关系,如/users/123/repos/234 使用正确的 HTTP 方法,如 GET/POST/PUT...上面说了这么多,下面让我们看一下如何在 Koa 中践行RESTful API最佳实践吧。...拿到路由分配的任务并执行 在 koa 中是一个中间件 为什么要用控制器 获取 HTTP 请求参数 Query String,如?...简单的说,Mongoose就是对node环境中MongoDB数据库操作的封装,一个对象模型(ODM)工具,将数据库中的数据转换为JavaScript对象以供我们在应用中使用。...在这里主要是以用户模块的crud为例来展示下如何在 koa 中践行RESTful API最佳实践。
使用Mongoose操作MongoDB数据库进行关联查询是一种比较常见的操作,操作方式有哪几种呢?下面用一个具体的案例来演示。...在 order_item 中查出 order_id,然后通过order_id 查询 order 集合,查出订单的信息。...定义 order 的 schema,导出模型,文件名为 order.js // 引入自定义的连接数据库的文件 var mongoose=require('....,'order_item'); 在需要查询的文件里引入定义的模型文件,执行操作 // 引入mongoose方便获取ID var mongoose = require('mongoose'); var OrderItemModel...需要注意的是,在 mongoose 里获取 ObjectId,要用 mongoose.Types.ObjectId 才能获取的到。
Schema——纯洁的数据库原型 1.1 什么是Schema 我理解Schema仅仅只是一断代码,他书写完成后程序依然无法使用,更无法通往数据库端 他仅仅只是数据库模型在程序片段中的一种表现,或者是数据属性模型...1.4 Schema.Types NodeJS中的基本数据类型都属于Schema.Type,另外Mongoose还定义了自己的类型 //举例: var ExampleSchema =...remove方法 4.Sub Docs 如同SQL数据库中2张表有主外关系,Mongoose将2个Document的嵌套叫做Sub-Docs(子文档) 简单的说就是一个Document嵌套另外一个...6.1 查询的方式 通常有2种查询方式,一种是直接查询,一种是链式查询(2种查询都是自己命名的) 6.1.1 直接查询 在查询时带有回调函数的,称之为直接查询,查询的条件往往通过API来设定,例如...,不是什么数据都能往数据库里丢或者显示到客户端的,数据的验证需要记住以下规则: 验证始终定义在SchemaType中 验证是一个内部中间件 验证是在一个Document被保存时默认启用的,除非你关闭验证
本教程需要事先了解 mongoose 对象关系映射(ORM)技术【https://mongoosejs.com/】 介绍 随着程序的增长,日志记录成为跟踪所有内容的关键部分。它对于调试目的尤为重要。...现在已经有了 npm 的日志记录模块。这些模块可以将日志存储在不同格式或级别的文件中。我们将使用流行的ORM Mongoose 讨论 Node.js Express 程序中的 API 日志记录。...那么如何创建一个 Mongoose 插件,以更清洁的方式为你进行记录并简化 API 日志? Mongoose 中的插件是什么? 在 Mongoose 中,模式是可插入的。...这是我们的模型:models/log.js const mongoose = require('mongoose') const Schema = mongoose.Schema const { ObjectId...步骤3:创建一个插件用来 diff 并将其保存到数据库 现在我们需要跟踪数据库中的前一个 document 并在保存到 mongodb 之前创建一个 diff。
在我们过去常用的RestFul API中,我们可能在不同的业务中需要调用同一个接口,但是各自所需的数据有不同的情况下,服务端为了同时满足两个需求则提供了更多的字段,这样导致了一个两个业务请求到的数据都包含了自己不需要的字段...后端开发同学应该都知道ORM的全称是对象关系映射(Object Relational Mapping,简称ORM)是通过使用描述对象和数据库之间映射的元数据,将面向对象语言程序中的对象自动持久化到关系数据库中...通过他我们可以定义一些Entity(实体),每个实体的数据字段,每个字段包含了数据类型,甚至是数据关系(一对多、多对多、多对一)。这些实体将映射到真实数据库中,创建真正的数据表。...而数据字段和关系也就生成对应的数据库表字段以及表字段与表字段的关系。...结语 其实总体来说,整个NestJs应用的开发体验还是蛮好的,相关的生态也发展的比较成熟,本项目仅是对相关技术的一个整体尝试,实际在开发过程中遇到的还有很多别的问题,比如GraphQL的N+1查询问题,
}) #mongoose基本使用 #mongoose的几个新的对象 在MongoDB中,多个Document可以组成Collection(以下简称集合),多个集合又可以组成数据库。...我们想要操作MongoDB数据,那就得先要具备上面所说的包含数据的“文档”,文档又是什么意思呢,请看如下介绍。...文档 —— 是MongoDB的核心概念,是键值对的一个有序集,在JavaScript里文档被表示成对象。同时它也是MongoDB中数据的基本单元,非常类似于关系型数据库管理系统中的行,但更具表现力。...集合 —— 由一组文档组成,如果将MongoDB中的一个文档比喻成关系型数据库中的一行,那么一个集合就相当于一张表。...: String Number Date Boolean Buffer ObjectId Mixed Array Model—— 由Schema构造生成的模型,根据Schema定义的数据类型规则,可操作具体的符合改规则的数据
——萧伯纳 前言 在大数据的驱使下,我们要实现数据持久化存储,数据共享,数据集中管理数据库是不二之选,小编在这里要阐述的是 mongodb 数据库,mongodb[1]是一个基于分布式文件存储的开源数据库系统...image.png 1.3 数据库的基本操作 显示表 show dbs; 切换数据库 use test; 插入数据 db.test.insert({name:"vivo"}); 查询数据 db.test.find...2.4 Schema 定义 Schema 来说其实是用来定义文档的基本字段和集合,也可以理解为表结构的定义。Schema 是与数据无关的 并不能直接操作数据库。...:'user'}) 在 mongoose 中,提供了 Schema 的类,我们可以在实例化的时候先定义mongoose.Schema,以免后续总是要出现丑陋的new mongoose.Schema()。...,callback中的第一个参数永远是错误信息,第二个参数是正确信息。
在开发内容管理系统时,经常会用到多表关联查询场景,如文章分类、文章详情、文章作者三张表,UML图如下: ? 业务需求如下:查询文章信息,并显示文章的分类以及文章的作者信息。...这样简单的一个需求在MySQL里要写一个很长的大SQL语句,但是在MongoDB里,凭借着Mongoose却可以轻松实现,实现步骤如下: 1....定义文章分类的schema生成模型导出,文件名 aritcleCate.js // 引入自定义的数据库连接文件 var mongoose = require('....定义用户的schema生成模型导出,文件名 user.js // 引入自定义的数据库连接文件 var mongoose = require('....定义文章的schema生成模型导出,文件名article.js // 引入自定义的数据库连接文件 var mongoose = require('.
Dotenv 是一个零依赖的模块,它能将环境变量中的变量从 .env 文件加载到 process.env 中。...) // mongodb://localhost:27017/test 如何在nestjs中使用dotenv呢?...在nestjs中使用环境变量, 推荐使用官方提供的@nestjs/config,开箱即用: @nestjs/config依赖于dotenv,可以通过key=value形式配置环境变量,项目会默认加载根目录下的...首先安装对应npm包 配置环境变量文件 定义读取环境变量的函数 配置@nestjs/config的方法 首先安装@nestjs/config 配置环境变量文件,配置两个文件,一个用于开发环境,一个用于生产环境...DB_PASSWD=root // 数据库名字 DB_DATABASE=blog .env.prod中的是上线要用的数据库信息,如果你的项目要上传到线上管理,为了安全性考虑,建议这个文件添加到.gitignore
应用中模块间的关系将由@Module()装饰器中携带的所有元数据描述。...注册订单提供者模块,如:负责订单 CRUD 的服务; controllers 注册订单控制器模块,如:负责订单 CRUD 的路由处理; imports 注册与订单相关联的模块,如:与订单关联的用户查询服务...读取请求对象 请求对象表示一个 HTTP 请求所携带的数据信息,如请求数据中的查询参数、路由参数、请求头、请求体等数据。...,HTTP 请求在经过控制器处理后应该将复杂的任务交由服务层进行处理,如:将复杂的订单生成、查询、更新及删除等操作进行封装。...; metatype:提供参数的元类型; 基于对象模式验证 下面是创建新 Cat 数据的create处理函数,在穿如若服务层之前仍然缺少验证 cat 数据完整且有效步骤,在遵守单一责任原则就可以通过自定义验证管道的方法做来
collection和document collection相当于关系型数据库中的表 document相当于一条数据,在这里有特别需要注意的一点是: collection不要求文档有相同的结构,在一个...collection文档中不必具有相同的fileds,对于单个field在一个collection中的不同文档中可以是不同的数据类型 实例方法methods documents是model的实例,document...在Mongoose中,意味着你可以在里嵌套另一个schema。...Model的多个静态辅助方法都可以查询文档 Query实例有一个.then()函数,用法类似Promise 我们看一下demo,查询persons表中name中属性last为Ghost值的文档,只查询...字段为 ObjectID 数组,ref 选项告诉mongoose 在填充的时候使用哪个 model,上面的例子就是指 Story 的 model。
5、mongoose验证 在创建集合规则时,可以设置当前字段的验证规则,验证失败就则输入插入失败。...validate: 自定义验证器 default: 默认值 获取错误信息:error.errors[‘字段名称’].message // 引入mongoose第三方模块 用来操作数据库 const mongoose...// 将错误信息打印到控制台中 console.log(err[attr]['message']); } }) 6、集合关联及实现 通常不同集合的数据之间是有关系的...,例如文章信息和用户信息存储在不同集合中,但文章是某个用户发表的,要查询文章的所有信息包括发表用户,就需要用到集合关联。...(result)); // 引入mongoose第三方模块 用来操作数据库 const mongoose = require('mongoose'); // 数据库连接 mongoose.connect
在 mysql 的官网下载 mysql,安装并启动服务。 这时候就可以用命令行来写 sql 操作数据库了。...数据库和对象关系的映射就叫做 ORM(Object Relational Mapping),也就是把表映射成对象,把表与表之间的关联映射成对象之间的关系。...比如 /xxx/:id 的 get 方法。 @Get、@Post、@Patch、@Delete 分别对应不同的请求方式。 @Param 是取路径中的参数,@Query 是取查询字符串的参数。...我们引入 Typeorm 来做数据库的 CRUD。 在根模块引入用于数据库连接的 Module 在刚创建的模块引入实体对应的 Module: 创建笔记实体,用 @Entity 标识。...数据库一开始有两条记录: 通过查询接口能正确的查出来: 然后测试下修改接口: 数据库中确实被修改了: 经过测试,对笔记单表的 CRUD 的功能正常。
最近,闲着没事,又把上个月写得代码拿出来了,随便完善一下没完成的评论的路由接口。 评论应该是在整个博客数据存储中,模型最为复杂的一部分了。首先要考虑的是和文章进行关联。...这个时候就要想该怎么做才能合理的管理这些层级关系,在删除父评论的同时又能把所有子评论一起删除。查询的时候如何去由根到叶顺序输出层级关系。...,post列中关联引用表(post表)的 _id(文章),在 hasChild 中记录是否存在回复。...如 post 中的一篇 pid 为 11 的文章下有一条评论,那么 key 中命名 11#001,这是第一条评论,如果该评论下存在一条回复,则回复的 key 为 11#001#001,下层亦是如此。...#\\d\\d\\d$`) 5 }) 6body.key = String(pid) + `#${String(comments + 1).padStart(3, 0)}` COPY 最后,看看数据库中的记录如何
领取专属 10元无门槛券
手把手带您无忧上云