时间:2021-05-26
最近开始学习NestJs这个框架。学习成本比其他框架相对高了很多。
其注册配置相对复杂一开始学起来有点摸不着哪跟哪;但这也是相比其他框架更规范严谨的体现。保证了大型项目的稳定健壮的使用!
在学习node基础框架Express和Koa的时候。对数据库的操作一直都是以编写SQL语句实现。需要什么编写什么。这样显得非常死板也不灵活。后来了解到NestJs是OOP思想编程(NestJs可以使用TypeScript也是OOP思想)才知道原来对数据库的操作可以用对象形式体现。在数据库中每一个表(Schema)都可以看作Nest框架中的一个对象。这样在对数据库操作就显得非常灵活
例如:(这是随便一个表的结构)
它可以看做成NestJs中的一个对象
这样一来对数据库中每个表的操作就显得非常简单了。
这里我们拿链接mongoDB操作来举例
根据官方文档使用mongoose
首先是安装所需依赖
npm install --save @nestjs/mongoose mongoose可以加个淘宝镜像:
–registry=https://registry.npm.taobao.org这个已经打的很熟练了用起来很方便。下载速度会相对快很多
安装完成后我们到app.module.ts中添加配置
app.module.ts
在imports:[]中添加相应配置
这个时候保存后在控制台就可以看到
DeprecationWarning: current URL string parser is deprecated, and will be removed in a future version. To use the new parser, pass option { useNewUrlParser: true } to MongoClient.connect
这么类似的一句话。就说明链接成功了
接着对模型注入(Schema)
在你相应的模块文件夹里创建schema文件夹。创建xx.schema.ts
例如我的是users/schemas/users.schema.ts
import * as mongoose from 'mongoose'export const UserSchema = new mongoose.Schema( { id: Number, name: String, introduction: String, headurl: String, bigurl: String, username: String, password: String, }, { collection: 'musicers', versionKey: false },)对应的是上图的表结构(collection:可以看作MongoDB中的一个表。)
接下来在相对应的users.module.ts模块进行配置添加
这么配置好后。我们就可以在service端操作了
service端 => users/users.service.ts
咋们就拿一个查找来测试
import { Model } from 'mongoose';import { Injectable } from '@nestjs/common';import { InjectModel } from '@nestjs/mongoose';import { User } from '../interface/users.interface';import { IUserService } from '../interface/user-service.interface';@Injectable()export class UsersService implements IUserService { constructor(@InjectModel('User') private readonly userModel: Model<User>) {} private static users:User[] = [ ] async findAll():Promise<User[]>{ //return UsersService.users return await this.userModel.find({}) //( 这里我们测试查找全部 ) }}controller端 => users/users.controller.ts
@Controller('users')export class UsersController { constructor(private readonly userservice: UsersService) { }@Get('getall') // @UseGuards(AuthGuard('jwt')) async findAll():Promise<User[]> { return await this.userservice.findAll() }}我们开一个接口出来
这里的3001是在main.ts中自定的。根据自己情况更改
然后我们可以访问
http://localhost:3001/users/getall
得到了结果
输出完成。其他操作也是根据类似的步骤进行
到此这篇关于NestJs使用Mongoose对MongoDB操作的方法的文章就介绍到这了,更多相关NestJs操作MongoDB内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了express使用Mongoose连接MongoDB操作。分享给大家供大家参考,具体如下:为何要学Mongoose?Mongoose是MongoD
Mongoose是什么?Mongoose是MongoDB的一个对象模型工具,封装了许多MongoDB对文档的的增删改查等常用方法,让NodeJS操作Mongod
前言Mongoose是在node.js异步环境下对mongodb进行便捷操作的对象模型工具那么要使用它,首先你得装上node.js和mongodb,关于mong
前言Mongoose是在nodejs环境下,对mongodb进行便捷操作的对象模型工具。本文介绍解(翻)密(译)Mongoose插件。Schema开始我们就要讲
使用mongoose可以让我们更好使用mongodb数据库,而不需要写繁琐的业务逻辑。安装npminstallmongoose初始化使用使用mongoose前,