【Nestjs学习日记】连接MongoDB表

作者:markzzw 时间:2024-2-26

线上代码:CodeSandbox

Github:zhangzewei/nest-learning-tutorial
系列阅读 【Nestjs学习日记】专栏

在 NestJS 中使用 MongoDB 数据库时,连接到数据库只是第一步。接下来,我们需要连接到具体的 MongoDB 表(集合),以便执行数据操作。NestJS 提供了一种简单且优雅的方式来定义和操作 MongoDB 表。

在本篇学习日记中,我们将探讨如何在 NestJS 中连接到 MongoDB 表,并执行常见的数据操作,如插入、查询、更新和删除数据。

准备工作

在开始之前,确保您已经完成了以下准备工作:

  • 已经连接到 MongoDB 数据库:请参考前一篇学习日记中的内容,确保您已经成功连接到 MongoDB 数据库。
  • 安装必要的依赖:我们将使用 @nestjs/mongoose 包来连接和操作 MongoDB 表。如果还没有安装该包,请运行以下命令进行安装:
shell 复制代码
  npm install --save @nestjs/mongoose mongoose

完成上述准备工作后,我们就可以开始连接到 MongoDB 表并进行数据操作了。

连接数据库表

连接MongoDB的表需要用到 MongooseModule 提供的 forFeature 方法。

php 复制代码
MongooseModule.forFeature([{ name: 'Cat', schema: CatSchema }]),

在 mongoDB 中,Schema 是一个表结构的展示,所以我们需要定义一个 Schema。

创建一个 CatSchema.ts

ts 复制代码
import { Prop, Schema, SchemaFactory } from '@nestjs/mongoose';
import { HydratedDocument } from 'mongoose';

export type CatDocument = HydratedDocument<Cat>;

@Schema()
export class Cat {
    @Prop()
    name: string;

    @Prop()
    age: number;

    @Prop()
    foods: string[];
}

export const CatSchema = SchemaFactory.createForClass(Cat);

随后在 cat.module.ts 中 import的数组中添加上 MongooseModule.forFeature([{ name: 'Cat', schema: CatSchema }])

ts 复制代码
import { Module } from '@nestjs/common';
import { CatController } from './cat.controller';
import { CatService } from './cat.service';
import { MongooseModule } from '@nestjs/mongoose';
import { Cat, CatSchema } from './schema/cat.schema';

@Module({
  imports: [
    MongooseModule.forFeature([{
      name: Cat.name, // 表名字
      schema: CatSchema // 表结构
    }]),
  ],
  controllers: [CatController],
  providers: [CatService],
  exports: [CatService],
})
export class CatModule { }

再将 cat.service.ts 中添加用于操作 cat 表的 Module。Models 是从 Schema 编译来的构造函数。 它们的实例就代表着可以从数据库保存和读取的 documents。 从数据库创建和读取 document 的所有操作都是通过 model 进行的。

ts 复制代码
import { Injectable } from '@nestjs/common';
import { Cat } from './schema/cat.schema';
import { InjectModel } from '@nestjs/mongoose';
import { Model } from 'mongoose';
import { CreateCatDto } from './dto/cat.dto';

@Injectable()
export class CatService {
  isChanged = false;
  constructor(
    @InjectModel(Cat.name) private catModel: Model<Cat> // 创建操作数据库的Module
  ) {}

  // 创建一条数据
  async create(createCatDto: CreateCatDto) {
    const createdCat = new this.catModel(createCatDto);
    return createdCat.save();
  }

  // 获取所有数据
  async findAll() {
    const cats = await this.catModel.find();
    return cats;
  }
}

把 cat service 中的 create 函数应用到 cat 的 post 方法,findAll 函数应用到 cat 的 get 方法,由此来验证数据库表的创建和获取是否成功。

cat.controller.ts

ts 复制代码
import { Controller, Get, Body, Post, Param, Put } from '@nestjs/common';
import { CatService } from './cat.service';
import { CreateCatDto, UpdateCatDto } from './dto/cat.dto';

@Controller('cat')
export class CatController {
  constructor(private catService: CatService) { }
  @Get()
  getCats() {
    return this.catService.findAll();
  }

  @Post()
  createCat(@Body() body: CreateCatDto) {
    return this.catService.create(body);
  }
}

验证

最开始在 Cloud MongoDB 查看数据库是没有任何数据。

随后在 postman 中进行 post 请求

随后刷新 Cloud MongoDB 中的数据库页面可以看到已经创建了一个 pets 数据库和 cats 表,并且已经存入了刚才请求的post的数据。

相关推荐
前端爆冲7 分钟前
项目中无用export的检测方案
前端
旧味清欢|18 分钟前
关注分离(Separation of Concerns)在前端开发中的实践演进:从 XMLHttpRequest 到 Fetch API
javascript·http·es6
热爱编程的小曾35 分钟前
sqli-labs靶场 less 8
前端·数据库·less
gongzemin1 小时前
React 和 Vue3 在事件传递的区别
前端·vue.js·react.js
Apifox1 小时前
如何在 Apifox 中通过 Runner 运行包含云端数据库连接配置的测试场景
前端·后端·ci/cd
-代号95271 小时前
【JavaScript】十四、轮播图
javascript·css·css3
树上有只程序猿1 小时前
后端思维之高并发处理方案
前端
庸俗今天不摸鱼2 小时前
【万字总结】前端全方位性能优化指南(十)——自适应优化系统、遗传算法调参、Service Worker智能降级方案
前端·性能优化·webassembly
QTX187302 小时前
JavaScript 中的原型链与继承
开发语言·javascript·原型模式
黄毛火烧雪下2 小时前
React Context API 用于在组件树中共享全局状态
前端·javascript·react.js