【Nestjs学习日记】连接MongoDB

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

线上代码:CodeSandbox

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

在 NestJS 中,使用 MongoDB 作为数据库是很常见的场景之一。MongoDB 是一个流行的 NoSQL 数据库,具有灵活的数据模型和丰富的查询功能。NestJS 提供了一种简单且优雅的方式来连接和操作 MongoDB 数据库。

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

准备工作

在开始之前,确保您已经安装了以下工具和依赖:

  • Node.js:确保您已经安装了 Node.js 运行时环境,并且可以在命令行中执行 nodenpm 命令。
  • NestJS CLI:通过运行 npm install -g @nestjs/cli 全局安装 NestJS CLI,以便创建和管理 NestJS 项目。
  • MongoDB:一般可以在本地安装一个MongoDB,这篇文章以学习为目的,所以将使用线上的Cloud MongoDB

首先安装 @nestjs/mongoose 包,它是 NestJS 的官方 MongoDB 连接库。您可以通过以下命令进行安装:

shell 复制代码
npm install --save @nestjs/mongoose mongoose

然后准备数据库,进入Cloud MongoDB,注册一个账号,然后根据引导,创建一个数据库,随后点击数据库中的 connect 按钮获取连接数据库的链接

其中 <password> 需要替换成设置的数据库密码,在 ? 前可以写上数据库名称。

perl 复制代码
mongodb+srv://${user}:${password}@cluster0.zxzpzz8.mongodb.net/${dbName}

连接 MongoDB 数据库

首先,我们需要在 NestJS 项目中创建一个模块来处理 MongoDB 的连接和配置。在命令行中切换到您的 NestJS 项目目录,并执行以下命令创建一个模块:

arduino 复制代码
nest generate module database

该命令将在 src 目录下创建一个名为 database 的模块,并生成相应的文件,使用 nest cli 创建的 Module 将会自动被引入 appModule。

接下来,我们需要在 database.module.ts 文件中配置 MongoDB 连接。请打开该文件,并根据以下示例进行编辑:

ts 复制代码
import { Module } from '@nestjs/common';
import { MongooseModule } from '@nestjs/mongoose';

const user = 'zzw';
const password = 'pass123';
const dbName = 'pets';

@Module({
    imports: [
        MongooseModule.forRoot(
            `mongodb+srv://${user}:${password}@cluster0.zxzpzz8.mongodb.net/${dbName}`
        ),
    ],
})
export class DatabaseModule { }

保存之后,重启项目会看到控制台打印出

ini 复制代码
[Nest] 36260  - 02/26/2024, 2:18:17 PM     LOG [InstanceLoader] MongooseModule dependencies initialized +11ms
[Nest] 36260  - 02/26/2024, 2:18:17 PM     LOG [InstanceLoader] DatabaseModule dependencies initialized +0ms

表示数据库连接已经成功。

相关推荐
wenzhangli72 小时前
Ooder A2UI 核心架构深度解析:WEB 拦截层的设计与实现
前端·架构
前端百草阁3 小时前
【前端性能优化全链路指南】从开发编写到构建运行的多维度实践
前端·性能优化
神探小白牙3 小时前
eCharts 多系列柱状图增加背景图
javascript·ecmascript·echarts
女生也可以敲代码3 小时前
AI时代下的50道前端开发面试题:从基础到大模型应用
前端·面试
ZhengEnCi3 小时前
M5-markconv自定义CSS样式指南 📝
前端·css·python
IT_陈寒3 小时前
SpringBoot自动配置的坑差点让我加班到天亮
前端·人工智能·后端
xingpanvip3 小时前
星盘接口开发文档:星相日历接口指南
android·开发语言·前端·css·php·lua
@PHARAOH4 小时前
WHAT - GitLens supercharged 插件
前端
TT模板4 小时前
苹果cms整合西瓜播放器XGplayer插件支持跳过片头尾
前端·html5
Wect4 小时前
React 性能优化精讲
前端·react.js·性能优化