一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - js教程 - NestJs使用Mongoose對MongoDB操作的方法

NestJs使用Mongoose對MongoDB操作的方法

2022-01-22 18:53ragga-time js教程

這篇文章主要介紹了NestJs使用Mongoose對MongoDB操作的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

最近開始學習NestJs這個框架。學習成本比其他框架相對高了很多。
其注冊配置相對復雜一開始學起來有點摸不著哪跟哪;但這也是相比其他框架更規范嚴謹的體現。保證了大型項目的穩定健壯的使用!

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

例如:(這是隨便一個表的結構)

NestJs使用Mongoose對MongoDB操作的方法

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

NestJs使用Mongoose對MongoDB操作的方法

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

根據官方文檔使用mongoose

首先是安裝所需依賴

npm install --save @nestjs/mongoose mongoose

可以加個淘寶鏡像:

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

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

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

app.module.ts

NestJs使用Mongoose對MongoDB操作的方法

在imports:[]中添加相應配置

MongooseModule.forRoot(‘mongodb://localhost/test')
//后面是MongoDB的位置(根據需要而定)
對應添加相應依賴
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)
在你相應的模塊文件夾里創建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模塊進行配置添加

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: [
  //這里添加配置。對應引入模塊(注意里面的括號結構別給坑了。這里我卡了半天)
    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中自定的。根據自己情況更改
然后我們可以訪問
http://localhost:3001/users/getall

NestJs使用Mongoose對MongoDB操作的方法

得到了結果

NestJs使用Mongoose對MongoDB操作的方法

輸出完成。其他操作也是根據類似的步驟進行

到此這篇關于NestJs使用Mongoose對MongoDB操作的方法的文章就介紹到這了,更多相關NestJs操作MongoDB內容請搜索服務器之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持服務器之家!

原文鏈接:https://blog.csdn.net/weixin_44273392/article/details/99445469

延伸 · 閱讀

精彩推薦
  • js教程原生js拖拽功能制作滑動條實例代碼

    原生js拖拽功能制作滑動條實例代碼

    這篇文章主要介紹了原生js拖拽功能制作滑動條實例教程,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的...

    蔣偉平3442022-01-17
  • js教程微信小程序抽獎組件的使用步驟

    微信小程序抽獎組件的使用步驟

    這篇文章主要給大家介紹了關于微信小程序抽獎組件的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需...

    い 狂奔的蝸牛10832021-12-29
  • js教程JavaScript實現打字游戲

    JavaScript實現打字游戲

    這篇文章主要為大家詳細介紹了JavaScript實現打字游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    一顆不甘墜落的流星3902022-01-21
  • js教程JavaScript canvas實現跟隨鼠標移動小球

    JavaScript canvas實現跟隨鼠標移動小球

    這篇文章主要為大家詳細介紹了JavaScript canvas實現跟隨鼠標移動小球,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一...

    清靜清源10352022-01-20
  • js教程js動態添加帶圓圈序號列表的實例代碼

    js動態添加帶圓圈序號列表的實例代碼

    這篇文章主要介紹了js動態添加帶圓圈序號列表的實例代碼,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參...

    一晃的春夏秋冬7102022-01-21
  • js教程JS+CSS實現動態時鐘

    JS+CSS實現動態時鐘

    這篇文章主要為大家詳細介紹了JS+CSS實現動態時鐘,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    易點都不懶5022022-01-21
  • js教程JS中錨點鏈接點擊平滑滾動并自由調整到頂部位置

    JS中錨點鏈接點擊平滑滾動并自由調整到頂部位置

    這篇文章主要介紹了JS中錨點鏈接點擊平滑滾動并自由調整到頂部位置,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的...

    是這樣的三月6362022-01-19
  • js教程詳解JavaScript中的this指向問題

    詳解JavaScript中的this指向問題

    這篇文章主要介紹了詳解JavaScript中的this指向問題,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下...

    清蒸胖頭魚8502022-01-17
主站蜘蛛池模板: 不良网站在线观看 | 女娃开嫩苞经历小说 | 日韩国产欧美精品综合二区 | 日本天堂影院在线播放 | 无码国产成人777爽死 | 精品国产福利一区二区在线 | 18欧美同性videos可播放 | 黑人性xxx | 亚洲视频999 | 免费一级国产大片 | 日本免费一区二区三区a区 日本免费三片在线观看 | 波多野结衣不卡 | 天堂在线中文字幕 | 亚洲欧美专区精品久久 | 国产精品精品 | 狠狠色婷婷 | 国产伦精品一区二区三区免费迷 | 国产91影院| 亚洲阿v天堂在线2017 | 息与子中文字幕完整在线 | 高h禁伦奶水女 | 天天黄视频| 国产成人影院在线观看 | 久久99亚洲AV无码四区碰碰 | 日韩欧美高清 | 美女模特被c免费视频 | 暖暖视频免费观看视频中国.韩剧 | 精品国产午夜久久久久九九 | jizz 日本亚洲 | 色综合图区 | 99在线精品日韩一区免费国产 | 日韩视频免费一区二区三区 | 男男视频18免费网站 | 日韩在线天堂免费观看 | 四虎麻豆 | 欧美福利二区 | 成人福利在线观看 | 成人 在线欧美亚洲 | 91制片厂(果冻传媒)原档破解 | 俄罗斯13一14处出血视频在线 | 91国内精品线免费播放 |