Comment utiliser Nest.js pour se connecter à la base de données MongoDB dans
node ? L'article suivant vous présentera comment utiliser MongoDB dans le framework de nœuds Nest.js. J'espère qu'il vous sera utile !
Lorsque vous apprendrez à connecter Nest à une base de données, vous rencontrerez inévitablement le problème de la sélection d'une base de données. Ici, l'auteur a choisi MongoDB
pour enregistrer l'utilisation simple. Vous pouvez choisir la base de données appropriée en fonction de différents besoins. MongoDB
记录一下简单使用。 大家可以根据不同需求选择合适的数据库。
贴出跟进看的文档以方便大家进一步学习 Nest 中文文档 ,MongoDB菜鸟教程
MongoDB 是一个基于分布式文件存储的数据库。由 C++ 语言编写。旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。
MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。
PostgreSql
小项目用 MongoDB
所以作者准备一起学习下,这次因为想做一个小项目练练手所以先用 MongoDB
看看怎么样。确保电脑已经安装了 MongoDB
没
记得弄完做一下环境配置,可以开机自启, 也可以选择自己启动哈hhh看个人
简单介绍一下 , Mongoose
是一个操作 MongoDB
的 Nodejs
驱动库
MongoDB
是数据库,Nodejs
是js的一个运行环境,Nodejs
不直接操作 Mongodb
,这个时候就需要相应的驱动程序来提供接口。
在 Nest 项目中安装一下依赖项,两种安装方式,自行选择
$ npm install --save @nestjs/mongoose mongoose // NPM 安装 $ yarn add @nestjs/mongoose mongoose // YARN 安装复制代码
安装完成后我们在 AppModule 文件中引入一下
/* app.module.ts */ import { Module } from '@nestjs/common'; import { AppController } from './app.controller'; import { AppService } from './app.service'; // 我自己准备的 USER 模块 import { UserModule } from './user/user.module'; // 引入 Mongoose import { MongooseModule } from '@nestjs/mongoose'; @Module({ // 用 forRoot 方法连接数据库 imports: [UserModule, MongooseModule.forRoot('mongodb://localhost/test')], controllers: [AppController], providers: [AppService], }) export class AppModule {}
这里用一个 User 模块来做 demo
这里我理解的基础功能模块包括 module
(模块) Controller
(控制器) Service
(提供者) Schema
(数据模型) 我们主要是用 Nest对
MongoDB
做增删改查 这几个模块目前暂时够用。
对这几个模块做一些简单介绍:
由于我们上面已经对 app.module.ts 该根模块已经引入过了 mongoose
所以下面我们之间看一下功能模块是怎样的
在Mongoose
中,一切都源于 Scheme,每个 Schema
都会映射到 MongoDB
的一个集合,并定义集合内文档的结构。Schema
被用来定义模型,而模型负责从底层创建和读取 MongoDB
的文档。
Schema
可以用 NestJS
内置的装饰器来创建,或者也可以自己动手使用 Mongoose
的常规方式。使用装饰器来创建 Schema
MongoDB est une base de données distribuée dans laquelle les fichiers sont stockés. Écrit en langage C++. Conçu pour fournir des solutions de stockage de données évolutives et performantes pour les applications WEB.
🎜🎜🎜MongoDB est un produit entre une base de données relationnelle et une base de données non relationnelle. C'est la base de données non relationnelle la plus riche en fonctionnalités et ressemble le plus à une base de données relationnelle. 🎜🎜PostgreSql
et les petits projets utilisent MongoDB
, l'auteur prévoit donc d'apprendre Cette fois-ci Parce que je voulais faire un petit projet pour mettre en pratique mes compétences, j'ai d'abord utilisé MongoDB
pour voir comment ça se passait. 🎜🎜Si vous avez des opinions différentes, n'hésitez pas à en discuter dans la zone de commentaires. 🎜MongoDB
est installé sur votre ordinateur Non🎜🎜🎜. 🎜N'oubliez pas de le terminer. Faites une configuration de l'environnement. Vous pouvez le démarrer automatiquement après le démarrage, ou vous pouvez choisir de le démarrer vous-même Hahh, cela dépend de l'individu 🎜🎜Mongoose
est une bibliothèque de pilotes Nodejs
qui exploite MongoDB
🎜🎜🎜 🎜MongoDB
est une base de données, Nodejs
est un environnement d'exécution pour js Nodejs
n'exploite pas directement Mongodb
. cette fois, un pilote correspondant est nécessaire pour fournir une interface. 🎜🎜🎜🎜Installez les dépendances dans le projet Nest, il existe deux méthodes d'installation, choisissez vous-même🎜/* user.schema.ts */ import { Prop, Schema, SchemaFactory } from '@nestjs/mongoose'; // @Prop 装饰器接受一个可选的参数,通过这个,你可以指示这个属性是否是必须的,是否需要默认值,或者是标记它作为一个常量,下面是例子 // SchemaFactory 是 mongoose 内置的一个方法做用是读取模式文档 并创建 Schema 对象 import { Document } from 'mongoose'; export type UserDocument = User & Document; @Schema() export class User extends Document { @Prop() name: string; // 设置值为必填 @Prop({ required: true }) age: number; @Prop() height: number; } export const UserSchema = SchemaFactory.createForClass(User);
/* user.service.ts */ import { Model } from 'mongoose'; import { InjectModel } from '@nestjs/mongoose'; import { User, UserDocument } from 'src/schema/user.schema'; import { CreateUserDto } from './user.dto'; @Injectable() export class UserService { // 注册Schema后,可以使用 @InjectModel() 装饰器将 User 模型注入到 UserService 中: constructor(@InjectModel('User') private userTest: Model<UserDocument>) {} // 添加 async create(createUserDto: CreateUserDto): Promise<User> { const createUser = new this.userTest(createUserDto); const temp = await createUser.save(); return temp; } // 查找 async findAll(): Promise<User[]> { // 这里是异步的 const temp = await this.userTest.find().exec(); return temp; } // 查找 async findOne(name: string): Promise<User[]> { // 这里是异步的 const temp = await this.userTest.find({ name }); return temp; } // 删除 async delete(sid: number) { // 这里是异步的 remove 方法删除成功并返回相应的个数 const temp = await this.userTest.remove({ _id: sid }); return temp; } // 修改 async updateUser(sid: string, data: any) { // 这里是异步的 remove 方法删除成功并返回相应的个数 const temp = await this.userTest.updateOne({ _id: sid }, { $set: data }); return temp; } }
module
( module) Contrôleur
(contrôleur) Service
(fournisseur) Schéma
(modèle de données) Nous utilisons principalement Nest pour associer
< code>MongoDB Ces modules d'ajout, de suppression, de modification et de vérification sont actuellement suffisants. 🎜🎜🎜🎜Une brève introduction à ces modules :🎜🎜mongoose
dans le module racine de app.module.ts ci-dessus, nous allons jeter un oeil à ce que les modules fonctionnels ressemblent à🎜🎜Mongoose
, tout vient de Scheme🎜, chaque Schema
sera mappé à une collection de MongoDB
, et définit la structure du documents au sein de la collection. Schema
est utilisé pour définir le modèle, et le modèle est responsable de la création et de la lecture des documents MongoDB
depuis le bas. 🎜🎜🎜🎜Le Schéma
peut être créé à l'aide du décorateur intégré de NestJS
, ou vous pouvez l'utiliser vous-même à l'aide du Mongoose. href="https ://link.juejin.cn?target=https%3A%2F%2Fmongoosejs.com%2Fdocs%2Fguide.html" target="_blank" rel="nofollow noopener noreferrer" title="https:// mongoosejs.com/ docs/guide.html" ref="nofollow noopener noreferrer">Voie normale 🎜. L'utilisation de décorateurs pour créer un Schéma
réduira considérablement les références et améliorera la lisibilité du code. L'auteur utilise ici la méthode officielle recommandée pour le créer avec un décorateur. Après tout, j'utilise Nest et je ne suis pas autorisé à utiliser quelque chose de spécial hhh. 🎜🎜🎜/* user.controller.ts */ // 引入 Nest.js 内置的各个功能 import { Body, Controller, Delete, Get, Param, Post, Put, Query } from '@nestjs/common'; // 引入用户服务 import { UserService } from './user.service'; // 引入创建用户 DTO 用于限制从接口处传来的参数 import { CreateUserDto } from './user.dto'; // 配置局部路由 @Controller('user') export class UserController { constructor(private readonly userService: UserService) {} // 创建user路由 user/createUser @Post('createUser') async createUser(@Body() body: CreateUserDto) { return this.userService.create(body); } //查找所有 user 路由 @Get('findAll') async findAll() { return this.userService.findAll(); } // 查找某一个用户路由 @Get('findOne') async findOne(@Query() query: any) { return this.userService.findOne(query.name); } // 删除一个用户的路由 @Delete(':sid') deleteUser(@Param() param: any) { return this.userService.delete(param.sid); } // 更改用户信息的路由 @Put(':sid') updateUser(@Body() body: any, @Param() param: any) { return this.userService.updateUser(param.sid, body); } }
控制器的目的是接收应用的特定请求。路由机制控制哪个控制器接收哪些请求。通常,每个控制器有多个路由,不同的路由可以执行不同的操作。
/* user.service.ts */ import { Model } from 'mongoose'; import { InjectModel } from '@nestjs/mongoose'; import { User, UserDocument } from 'src/schema/user.schema'; import { CreateUserDto } from './user.dto'; @Injectable() export class UserService { // 注册Schema后,可以使用 @InjectModel() 装饰器将 User 模型注入到 UserService 中: constructor(@InjectModel('User') private userTest: Model<UserDocument>) {} // 添加 async create(createUserDto: CreateUserDto): Promise<User> { const createUser = new this.userTest(createUserDto); const temp = await createUser.save(); return temp; } // 查找 async findAll(): Promise<User[]> { // 这里是异步的 const temp = await this.userTest.find().exec(); return temp; } // 查找 async findOne(name: string): Promise<User[]> { // 这里是异步的 const temp = await this.userTest.find({ name }); return temp; } // 删除 async delete(sid: number) { // 这里是异步的 remove 方法删除成功并返回相应的个数 const temp = await this.userTest.remove({ _id: sid }); return temp; } // 修改 async updateUser(sid: string, data: any) { // 这里是异步的 remove 方法删除成功并返回相应的个数 const temp = await this.userTest.updateOne({ _id: sid }, { $set: data }); return temp; } }
等下和其他功能一起在 Module 中引入。
控制器的目的是接收应用的特定请求。路由机制控制哪个控制器接收哪些请求。通常,每个控制器有多个路由,不同的路由可以执行不同的操作。
/* user.controller.ts */ // 引入 Nest.js 内置的各个功能 import { Body, Controller, Delete, Get, Param, Post, Put, Query } from '@nestjs/common'; // 引入用户服务 import { UserService } from './user.service'; // 引入创建用户 DTO 用于限制从接口处传来的参数 import { CreateUserDto } from './user.dto'; // 配置局部路由 @Controller('user') export class UserController { constructor(private readonly userService: UserService) {} // 创建user路由 user/createUser @Post('createUser') async createUser(@Body() body: CreateUserDto) { return this.userService.create(body); } //查找所有 user 路由 @Get('findAll') async findAll() { return this.userService.findAll(); } // 查找某一个用户路由 @Get('findOne') async findOne(@Query() query: any) { return this.userService.findOne(query.name); } // 删除一个用户的路由 @Delete(':sid') deleteUser(@Param() param: any) { return this.userService.delete(param.sid); } // 更改用户信息的路由 @Put(':sid') updateUser(@Body() body: any, @Param() param: any) { return this.userService.updateUser(param.sid, body); } }
模块是具有 @Module()
装饰器的类。 @Module()
装饰器提供了元数据,Nest 用它来组织应用程序结构。
我们把以上内容引入到我们的 User 模块中
/* user.module.ts */ import { Module } from '@nestjs/common'; import { UserController } from './user.controller'; import { UserService } from './user.service'; import { MongooseModule } from '@nestjs/mongoose'; import { UserSchema } from 'src/schema/user.schema'; @Module({ // MongooseModule提供了forFeature()方法来配置模块,包括定义哪些模型应该注册在当前范围中。 // 如果你还想在另外的模块中使用这个模型,将MongooseModule添加到CatsModule的exports部分并在其他模块中导入CatsModule。 // 这里的 name:'User' 为数据库表名称与 service 中注入的表名称对应两者不一样会报错 imports: [MongooseModule.forFeature([{ name: 'User', schema: UserSchema }])], controllers: [UserController], providers: [UserService], }) export class UserModule {}
app.setGlobalPrefix('api');
意思就是所有请求前面会有一个 /api/
PostMan
和 MongoDB Compass
官方推荐的可视化工具查看效果这里我使用 POST
请求,路由为/api/user/createUser
因为要限制请求参数的数据类型所以这里方式为 application/json
因为这里我们之前定义的 User 数据模型为 name,age,height, 所以请求里面只需要这几个参数即可,别的就算写进去也添加不到集合中
Postman
打开 MongoDB Compass 查看数据
可以看到我们已经添加到数据库中一条数据,接下来我们在添加两条,方便等会的查询/删除/更改操作
这里我使用 GET
请求,,路由为/api/user/findAll
因为这里是查 User 集合内所有数据,所以不用添加请求参数
Postman
打开 MongoDB Compass 查看数据
可以看到我们已经查询到数据库中刚才在 User
集合中添加的三条数据切记要点 REFRESH
建不然软件不会自己刷新
这里我使用 GET
请求,路由为/api/user/findOne
因为这里是查 User 集合内对应搜索条件的数据集合,这里我们用的是name 去查询的。也可以用唯一值 id 去查询。
Postman
可以看到返回结果是一个集合,了解更多查询方式可以看下官网
这里我使用 PUT
请求,路由为/api/user/:sid
因为要限制请求参数的数据类型所以这里方式为 application/json
因为这里我们之前定义的 User 数据模型为 age,height, 所以请求里面只需要这几个参数即可,别的就算写进去也添加不到集合中,我们这里传入数据库中小明的_id 61eea1b4144ea374a5b8455a
传入 Param
中 ,然后把要修改的内容放入 Body
中
Postman
打开 MongoDB Compass 查看数据
可以看到我们已经把小明的年龄与身高做了修改
Ici, j'utilise DELETE
pour demander, et la route est /api/user/:sid
car je veux limiter le type de données de les paramètres de la requête, donc la méthode ici est application/json
DELETE
请求,路由为/api/user/:sid
因为要限制请求参数的数据类型所以这里方式为 application/json
我们这里传入数据库中小明的_id 61eea1b4144ea374a5b8455a
传入 Param
中 ,并发起请求
Postman
打开 MongoDB Compass 查看数据
可以看到小明的信息已经不存在了
Nest.js
中使用 Mongoose 对 MongoDB
数据的基础操作。并完成了在 Nest 中使用装饰器来创建 数据模型 Schema
61eea1b4144ea374a5b8455a
de Xiao Ming dans Param
et lançons une requête MongoDB
Opérations de base sur les données. Et j'ai fini d'utiliser des décorateurs pour créer des modèles de données Schéma
dans Nest. 🎜🎜En regardant la documentation, il semble que vous puissiez également utiliser le 🎜TypeORM🎜 intégré dans Nest pour créer des modèles. Les amis intéressés peuvent y jeter un œil. Quand je reviendrai pour apprendre d'autres connexions à la base de données, je le lirai et verrai comment le faire fonctionner. 🎜🎜Il y a encore beaucoup à apprendre sur Nest, comme les pipelines, les middlewares, les intercepteurs, les gardes de routage, etc. Je prévois de les utiliser pour écrire de petites démos pour approfondir ma compréhension personnelle, sinon c'est difficile à comprendre simplement en lisant. la documentation. Voici, je n'entrerai pas dans les détails ~ Ce que je sais jusqu'à présent, c'est que l'utilisation de pipelines pour déterminer les types de requêtes est très utile. Les amis intéressés peuvent en apprendre davantage sur 🎜Class Validator🎜🎜🎜🎜Pour plus de connaissances sur les nœuds, veuillez. visite : 🎜tutoriel nodejs 🎜 ! 🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!