1、下载mongodb数据库
2、安装Typegoose
$ npm install --save mongoose
$ npm install --save-dev @nestjs/mongoose
$ npm i @typegoose/typegoose
3、main.ts
import { NestFactory } from '@nestjs/core';
import { SwaggerModule, DocumentBuilder } from '@nestjs/swagger';
import { AppModule } from './app.module';
// 导入mongoose
import * as mongoose from 'mongoose'
async function bootstrap() {
//连接数据库
mongoose.connect('mongodb://localhost:27017/nest-blog-api')
const app = await NestFactory.create(AppModule);
const config = new DocumentBuilder()
// 标题
.setTitle('NestJs博客API')
// 描述
.setDescription('我的第一个NestJs项目')
// 版本
.setVersion('1.0')
.build();
// 引入Swagger
const document = SwaggerModule.createDocument(app, config);
// 接口文档路径
SwaggerModule.setup('api-docs', app, document);
// 监听端口号3000
await app.listen(3000);
}
bootstrap();
4、在之前建好的posts文件夹中新建model.ts文件。

model.ts内容
import { getModelForClass, prop } from "@typegoose/typegoose"
export class postModel{
@prop()
//字段名
title:string
@prop()
//字段名
content:string
}
export const PostModel =getModelForClass(postModel)
5、使用MongoDB的查询功能,PostModel则是刚才新建的文件。
import { Body, Controller, Delete, Get, Param, Post, Put, Query } from '@nestjs/common';
import { ApiOperation, ApiProperty, ApiTags } from '@nestjs/swagger';
import { PostModel } from './posts.model';
@Controller('posts')
@ApiTags('帖子')
export class PostsController {
@Get()
@ApiOperation({summary:'显示帖子列表'})
async index() {
//查询
return await PostModel.find()
}
}
这篇博客介绍了如何在NestJS应用中集成Typegoose库来操作MongoDB数据库,包括数据库的连接、模型定义、以及基本的查询操作。通过创建一个PostModel,展示了如何定义字段并实现获取帖子列表的功能。
334





