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

相关推荐
江晓曼*凡云基地14 小时前
Hermes Agent 多Agent模式:并行拆解复杂任务的实战指南
javascript·windows·microsoft
AC赳赳老秦14 小时前
OpenClaw与WPS宏联动:批量执行WPS复杂操作,解决办公表格批量处理难题
java·前端·数据库·自动化·需求分析·deepseek·openclaw
小白学大数据14 小时前
Python 爬虫动态 JS 渲染与无头浏览器实战选型指南
开发语言·javascript·爬虫·python
Larcher14 小时前
# 告别“古法编程”:吴恩达 AI 课程学习笔记与生日贺卡项目实战
前端·github·ai编程
用户8524950718414 小时前
# 大二前端新人的AI初体验:跟着吴恩达学“Vibe Coding”,我如何用提示词“指挥”AI写代码?
前端
bupt_0114 小时前
Hermes深入理解及源码解析(二):Hermes的记忆机制
java·服务器·前端
飘尘14 小时前
WebAssembly 是什么?它为什么重要?
前端·javascript
情绪总是阴雨天~14 小时前
大模型 Function Call(函数调用)详解:原理、实践与数据库智能查询 Agent
前端·数据库·人工智能
之歆14 小时前
DAY_10 JavaScript 深度解析:原型链 · 引用类型 · 内置对象 · 数组方法全攻略(上)
开发语言·javascript·ecmascript
GalenZhang88815 小时前
OpenClaw (2026.4.x 至 2026.5.12) 升级问题及解决
前端·chrome·openclaw