亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

NestJs使用Mongoose對MongoDB操作的方法

 更新時間:2021年02月22日 10:47:00   作者:ragga-time  
這篇文章主要介紹了NestJs使用Mongoose對MongoDB操作的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

最近開始學(xué)習(xí)NestJs這個框架。學(xué)習(xí)成本比其他框架相對高了很多。
其注冊配置相對復(fù)雜一開始學(xué)起來有點摸不著哪跟哪;但這也是相比其他框架更規(guī)范嚴(yán)謹(jǐn)?shù)捏w現(xiàn)。保證了大型項目的穩(wěn)定健壯的使用!

在學(xué)習(xí)node基礎(chǔ)框架Express和Koa的時候。對數(shù)據(jù)庫的操作一直都是以編寫SQL語句實現(xiàn)。需要什么編寫什么。這樣顯得非常死板也不靈活。后來了解到NestJs是OOP思想編程(NestJs可以使用TypeScript也是OOP思想)才知道原來對數(shù)據(jù)庫的操作可以用對象形式體現(xiàn)。在數(shù)據(jù)庫中每一個表(Schema)都可以看作Nest框架中的一個對象。這樣在對數(shù)據(jù)庫操作就顯得非常靈活

例如:(這是隨便一個表的結(jié)構(gòu))

在這里插入圖片描述

它可以看做成NestJs中的一個對象

在這里插入圖片描述

這樣一來對數(shù)據(jù)庫中每個表的操作就顯得非常簡單了。
這里我們拿鏈接mongoDB操作來舉例

根據(jù)官方文檔使用mongoose

首先是安裝所需依賴

npm install --save @nestjs/mongoose mongoose

可以加個淘寶鏡像:

–registry=https://registry.npm.taobao.org

這個已經(jīng)打的很熟練了用起來很方便。下載速度會相對快很多

安裝完成后我們到app.module.ts中添加配置

app.module.ts

在這里插入圖片描述

在imports:[]中添加相應(yīng)配置

MongooseModule.forRoot(‘mongodb://localhost/test')
//后面是MongoDB的位置(根據(jù)需要而定)
對應(yīng)添加相應(yīng)依賴
import { Module } from ‘@nestjs/common';
import { MongooseModule } from ‘@nestjs/mongoose';

這個時候保存后在控制臺就可以看到
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)
在你相應(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 },
)

對應(yīng)的是上圖的表結(jié)構(gòu)(collection:可以看作MongoDB中的一個表。)
接下來在相對應(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: [
  //這里添加配置。對應(yīng)引入模塊(注意里面的括號結(jié)構(gòu)別給坑了。這里我卡了半天)
    MongooseModule.forFeature([
      { name: 'User', schema: UserSchema }
    ])
  ],
  controllers: [UsersController],
  providers: [
    UsersService,
   ],
})
export class UsersModule {}

這么配置好后。我們就可以在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中自定的。根據(jù)自己情況更改
然后我們可以訪問
http://localhost:3001/users/getall

在這里插入圖片描述

得到了結(jié)果

在這里插入圖片描述

輸出完成。其他操作也是根據(jù)類似的步驟進(jìn)行

到此這篇關(guān)于NestJs使用Mongoose對MongoDB操作的方法的文章就介紹到這了,更多相關(guān)NestJs操作MongoDB內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論