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中substr,substring,slice.splice的区别说明
Nov 25 Javascript
基于jquery的大众点评,分类导航实现代码
Aug 23 Javascript
JavaScript中:表达式和语句的区别[译]
Sep 17 Javascript
css3元素简单的闪烁效果实现(html5 jquery)
Dec 28 Javascript
探索angularjs+requirejs全面实现按需加载的套路
Feb 26 Javascript
JS+Canvas 实现下雨下雪效果
May 18 Javascript
js 点击a标签 获取a的自定义属性方法
Nov 21 Javascript
解决option标签selected=&quot;selected&quot;属性失效的问题
Nov 06 Javascript
利用10行js代码实现上下滚动公告效果
Dec 08 Javascript
AngularJS基于http请求实现下载php生成的excel文件功能示例
Jan 23 Javascript
js实现文章目录索引导航(table of content)
May 10 Javascript
使用Vue.js和MJML创建响应式电子邮件
Mar 23 Vue.js
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
PHP在特殊字符前加斜杠的实现代码
2011/07/17 PHP
初步介绍PHP扩展开发经验分享
2012/09/06 PHP
PHP按指定键值对二维数组进行排序的方法
2015/12/22 PHP
php实现数组重复数字统计实例
2018/09/30 PHP
laravel框架路由分组,中间件,命名空间,子域名,路由前缀实例分析
2020/02/18 PHP
js常见表单应用技巧
2008/01/09 Javascript
JS拖动技术 关于setCapture使用
2010/12/09 Javascript
js去除重复字符串两种实现方法
2013/01/09 Javascript
用javascript删除当前行,添加行(示例代码)
2013/11/25 Javascript
jQuery中height()方法用法实例
2014/12/24 Javascript
jquery实现鼠标滑过显示二级下拉菜单效果
2015/08/24 Javascript
javascript截图 jQuery插件imgAreaSelect使用详解
2016/05/04 Javascript
Bootstrap组件之下拉菜单,多级菜单及按钮布局方法实例
2017/05/25 Javascript
JavaScript 获取元素在父节点中的下标(推荐)
2017/06/28 Javascript
JS中使用media实现响应式布局
2017/08/04 Javascript
javascript 通过键名获取键盘的keyCode方法
2017/12/31 Javascript
jQuery实现常见的隐藏与展示列表效果示例
2018/06/04 jQuery
详解vue+webpack+express中间件接口使用
2018/07/17 Javascript
深入了解Hybrid App技术的相关知识
2019/07/17 Javascript
Vue 解决路由过渡动画抖动问题(实例详解)
2020/01/05 Javascript
[00:12]DAC2018 no[o]ne亮相SOLO赛 他是否如他的id一样无人可挡?
2018/04/06 DOTA
深入解析Python中的集合类型操作符
2015/08/19 Python
解决Python出现_warn_unsafe_extraction问题的方法
2016/03/24 Python
浅谈Pandas中map, applymap and apply的区别
2018/04/10 Python
Python csv文件记录流程代码解析
2020/07/16 Python
解决python运行效率不高的问题
2020/07/20 Python
Python 微信公众号文章爬取的示例代码
2020/11/30 Python
使用css创建三角形 使用CSS3创建3d四面体原理及代码(html5实践)
2013/01/06 HTML / CSS
来自世界上最好大学的在线课程:edX
2018/10/16 全球购物
我的求职计划书
2014/01/10 职场文书
小学捐书活动总结
2014/07/05 职场文书
宾馆仓管员岗位职责
2014/07/27 职场文书
运动会广播稿300字
2015/08/19 职场文书
详解python的内存分配机制
2021/05/10 Python
Python趣味挑战之教你用pygame画进度条
2021/05/31 Python
详解JavaScript中Arguments对象用途
2021/08/30 Javascript