【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的数据。

相关推荐
Amumu1213820 分钟前
Vue核心(二)
前端·javascript·vue.js
墨轩尘39 分钟前
qiankun的简单使用
前端·vue.js·前端框架
EEEzhenliang1 小时前
CSS样式所有使用方式(书写位置)
前端·css
2501_944424121 小时前
Flutter for OpenHarmony游戏集合App实战之记忆翻牌配对消除
android·java·开发语言·javascript·windows·flutter·游戏
2501_944526421 小时前
Flutter for OpenHarmony 万能游戏库App实战 - 设置功能实现
android·javascript·flutter·游戏·harmonyos
愚公移码1 小时前
蓝凌EKP产品:关联机制浅析
java·服务器·前端
汉堡go2 小时前
python_chapter6
前端·数据库·python
wusp19942 小时前
v-model 和 :value 的深度解析
前端·javascript·vue.js
2501_944424122 小时前
Flutter for OpenHarmony游戏集合App实战之记忆翻牌表情图案
开发语言·javascript·flutter·游戏·harmonyos
Code知行合壹2 小时前
Vue项目中SVG图标
前端·vue.js