NestJs使用Mongoose對(duì)MongoDB操作的方法
最近開(kāi)始學(xué)習(xí)NestJs這個(gè)框架。學(xué)習(xí)成本比其他框架相對(duì)高了很多。
其注冊(cè)配置相對(duì)復(fù)雜一開(kāi)始學(xué)起來(lái)有點(diǎn)摸不著哪跟哪;但這也是相比其他框架更規(guī)范嚴(yán)謹(jǐn)?shù)捏w現(xiàn)。保證了大型項(xiàng)目的穩(wěn)定健壯的使用!
在學(xué)習(xí)node基礎(chǔ)框架Express和Koa的時(shí)候。對(duì)數(shù)據(jù)庫(kù)的操作一直都是以編寫SQL語(yǔ)句實(shí)現(xiàn)。需要什么編寫什么。這樣顯得非常死板也不靈活。后來(lái)了解到NestJs是OOP思想編程(NestJs可以使用TypeScript也是OOP思想)才知道原來(lái)對(duì)數(shù)據(jù)庫(kù)的操作可以用對(duì)象形式體現(xiàn)。在數(shù)據(jù)庫(kù)中每一個(gè)表(Schema)都可以看作Nest框架中的一個(gè)對(duì)象。這樣在對(duì)數(shù)據(jù)庫(kù)操作就顯得非常靈活
例如:(這是隨便一個(gè)表的結(jié)構(gòu))
它可以看做成NestJs中的一個(gè)對(duì)象
這樣一來(lái)對(duì)數(shù)據(jù)庫(kù)中每個(gè)表的操作就顯得非常簡(jiǎn)單了。
這里我們拿鏈接mongoDB操作來(lái)舉例
根據(jù)官方文檔使用mongoose
首先是安裝所需依賴
npm install --save @nestjs/mongoose mongoose
可以加個(gè)淘寶鏡像:
–registry=https://registry.npm.taobao.org
這個(gè)已經(jīng)打的很熟練了用起來(lái)很方便。下載速度會(huì)相對(duì)快很多
安裝完成后我們到app.module.ts中添加配置
app.module.ts
在imports:[]中添加相應(yīng)配置
MongooseModule.forRoot(‘mongodb://localhost/test') //后面是MongoDB的位置(根據(jù)需要而定) 對(duì)應(yīng)添加相應(yīng)依賴 import { Module } from ‘@nestjs/common'; import { MongooseModule } from ‘@nestjs/mongoose';
這個(gè)時(shí)候保存后在控制臺(tái)就可以看到
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
這么類似的一句話。就說(shuō)明鏈接成功了
接著對(duì)模型注入(Schema)
在你相應(yīng)的模塊文件夾里創(chuàng)建schema文件夾。創(chuàng)建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 }, )
對(duì)應(yīng)的是上圖的表結(jié)構(gòu)(collection:可以看作MongoDB中的一個(gè)表。)
接下來(lái)在相對(duì)應(yīng)的users.module.ts模塊進(jìn)行配置添加
import { Module } from '@nestjs/common'; import { MongooseModule, getModelToken } from '@nestjs/mongoose'; import { UsersController } from './users.controller'; import { UsersService } from './services/users.service'; import { UserSchema } from './schemas/users.schemas'; @Module({ imports: [ //這里添加配置。對(duì)應(yīng)引入模塊(注意里面的括號(hào)結(jié)構(gòu)別給坑了。這里我卡了半天) MongooseModule.forFeature([ { name: 'User', schema: UserSchema } ]) ], controllers: [UsersController], providers: [ UsersService, ], }) export class UsersModule {}
這么配置好后。我們就可以在service端操作了
service端 => users/users.service.ts
咋們就拿一個(gè)查找來(lái)測(cè)試
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({}) //( 這里我們測(cè)試查找全部 ) } }
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() } }
我們開(kāi)一個(gè)接口出來(lái)
這里的3001是在main.ts中自定的。根據(jù)自己情況更改
然后我們可以訪問(wèn)
http://localhost:3001/users/getall
得到了結(jié)果
輸出完成。其他操作也是根據(jù)類似的步驟進(jìn)行
到此這篇關(guān)于NestJs使用Mongoose對(duì)MongoDB操作的方法的文章就介紹到這了,更多相關(guān)NestJs操作MongoDB內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
layer ui 導(dǎo)入文件之前傳入數(shù)據(jù)的實(shí)例
今天小編就為大家分享一篇layer ui 導(dǎo)入文件之前傳入數(shù)據(jù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09JS實(shí)現(xiàn)定時(shí)任務(wù)每隔N秒請(qǐng)求后臺(tái)setInterval定時(shí)和ajax請(qǐng)求問(wèn)題
這篇文章主要介紹了JS實(shí)現(xiàn)定時(shí)任務(wù)每隔N秒請(qǐng)求后臺(tái)setInterval定時(shí)和ajax請(qǐng)求 的相關(guān)資料,需要的朋友可以參考下2017-10-10Ionic項(xiàng)目中Native Camera的使用方法
Ionic項(xiàng)目中如何使用Native Camera?這篇文章主要介紹了Ionic項(xiàng)目中Native Camera的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06javascript實(shí)現(xiàn)textarea中tab鍵的縮排處理方法
這篇文章主要介紹了javascript實(shí)現(xiàn)textarea中tab鍵的縮排處理方法,涉及javascript處理鼠標(biāo)事件及頁(yè)面元素的相關(guān)技巧,需要的朋友可以參考下2015-06-06JavaScript webpack模塊打包器如何優(yōu)化前端性能
本系列主要整理前端面試中需要掌握的知識(shí)點(diǎn)。本節(jié)介紹webpack如何優(yōu)化前端性能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08