NestJs使用Mongoose对MongoDB操作的方法


Posted in Javascript onFebruary 22, 2021

最近开始学习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内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
javascript引用对象的方法
Jan 11 Javascript
js/jquery判断浏览器的方法小结
Sep 02 Javascript
JavaScript语言对Unicode字符集的支持详解
Dec 30 Javascript
flash+jQuery实现可关闭及重复播放的压顶广告
Apr 15 Javascript
JavaScript中的闭包
Feb 24 Javascript
javascript简单实现跟随滚动条漂浮的返回顶部按钮效果
Aug 19 Javascript
利用vue实现模态框组件
Dec 19 Javascript
微信小程序 Nginx环境配置详细介绍
Feb 14 Javascript
原生JS实现图片懒加载(lazyload)实例
Jun 13 Javascript
Vue2.0 v-for filter列表过滤功能的实现
Sep 07 Javascript
vue实现Excel文件的上传与下载功能的两种方式
Jun 28 Javascript
9个JavaScript日常开发小技巧
Oct 06 Javascript
linux服务器快速卸载安装node环境(简单上手)
Feb 22 #Javascript
k8s node节点重新加入master集群的实现
Feb 22 #Javascript
js实现简单图片拖拽效果
Feb 22 #Javascript
用vite搭建vue3应用的实现方法
Feb 22 #Vue.js
详解Vite的新体验
Feb 22 #Javascript
详解Vue3.0 + TypeScript + Vite初体验
Feb 22 #Vue.js
Nest.js 授权验证的方法示例
Feb 22 #Javascript
You might like
Memcache 在PHP中的使用技巧
2010/02/08 PHP
php堆排序实现原理与应用方法
2015/01/03 PHP
php中异常处理方法小结
2015/01/09 PHP
php搜索文件程序分享
2015/10/30 PHP
浅谈php中fopen不能创建中文文件名文件的问题
2017/02/06 PHP
Yii2实现自定义独立验证器的方法
2017/05/05 PHP
PHP实现的最大正向匹配算法示例
2017/12/19 PHP
PHP getName()函数讲解
2019/02/03 PHP
PHP时间类完整代码实例
2021/02/26 PHP
js计数器代码
2006/11/04 Javascript
js获取指定的cookie的具体实现
2014/02/20 Javascript
使用变量动态设置js的属性名
2014/10/19 Javascript
Jquery使用val方法读写value值
2015/05/18 Javascript
原生js实现移动端瀑布流式代码示例
2015/12/18 Javascript
jQuery自定义插件详解及实例代码
2016/12/29 Javascript
vue 使用Jade模板写html,stylus写css的方法
2018/02/23 Javascript
vue实现简单的星级评分组件源码
2018/11/16 Javascript
使用Typescript和ES模块发布Node模块的方法
2020/05/25 Javascript
微信小程序实现弹框效果
2020/05/26 Javascript
使用node-media-server搭建一个简易的流媒体服务器
2021/01/20 Javascript
[42:25]2018DOTA2亚洲邀请赛 4.5 淘汰赛 LGD vs Liquid 第三场
2018/04/06 DOTA
使用Python操作MySQL的一些基本方法
2015/08/16 Python
python中如何正确使用正则表达式的详细模式(Verbose mode expression)
2017/11/08 Python
详解Django rest_framework实现RESTful API
2018/05/24 Python
python编辑用户登入界面的实现代码
2018/07/16 Python
Python 从一个文件中调用另一个文件的类方法
2019/01/10 Python
Python内置加密模块用法解析
2019/11/25 Python
Python3 filecmp模块测试比较文件原理解析
2020/03/23 Python
Python截图并保存的具体实例
2021/01/14 Python
adidas爱尔兰官方网站:阿迪达斯运动鞋和运动服
2019/11/01 全球购物
电大自我鉴定
2013/10/27 职场文书
试用期自我评价怎么写
2015/03/10 职场文书
2016年春节慰问信息
2015/03/25 职场文书
使用springMVC所需要的pom配置
2021/09/15 Java/Android
MySQL详细讲解变量variables的用法
2022/06/21 MySQL
python+opencv实现目标跟踪过程
2022/06/21 Python