最近开始学习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
得到了结果
输出完成。其他操作也是根据类似的步骤进行
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。




