最近开始学习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:[]中添加相应配置
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
得到了结果
输出完成。其他操作也是根据类似的步骤进行
更新动态
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]