大前端nestjs入门教程系列(四):如何nestjs整合mysql数据库

经过前面的几篇文章,想必大家已经对nestjs有了基础的了解,那么这篇文章就带大家玩玩数据库,学会了这篇,就离大前端又进了一步

Nest与数据库无关,使你可以轻松地与任何 SQL 或 NoSQL 数据库集成。 根据你的喜好,你有多种选择。 在最一般的层面上,将 Nest 连接到数据库只是为数据库加载适当的 Node.js 驱动程序的问题,下面我们就学习下如何整合mysql数据库

为了与 SQL 和 NoSQL 数据库集成,Nest 提供了 @nestjs/typeorm 包。 TypeORM 是可用于 TypeScript 的最成熟的对象关系映射器 (ORM)。 由于它是用 TypeScript 编写的,因此可以很好地与 Nest 框架集成。

依赖的安装


npm install --save @nestjs/typeorm typeorm mysql2

安装完成后,我们在app.module.ts中引入mysql的配置

import { Module } from '@nestjs/common';
import { TypeOrmModule } from '@nestjs/typeorm';@Module({imports: [TypeOrmModule.forRoot({type: 'mysql',host: 'localhost',port: 3306,username: 'root',  //改成自己账户password: 'root',  //改成自己密码database: 'test',  //改成自己的数据库entities: [],synchronize: true,}),],
})
export class AppModule {}

创建实体类

这里的实体类就是java中的bean对象,了解java的不陌生,那么我们如何在这里定义呢?
user.entity.ts

import { Column, Entity, PrimaryGeneratedColumn } from "typeorm";@Entity()
export class newUser{@PrimaryGeneratedColumn()id:number@Column("varchar",{length:8})firstName@Column()lastName:string@Column()age:number}

创建user模块

users.module.ts

import { Module } from '@nestjs/common';
import { TypeOrmModule } from '@nestjs/typeorm';
import { newUser } from './user.entity';
import { UsersController } from './users.controllers';
import { UsersService } from './users.service';@Module({imports:[TypeOrmModule.forFeature([newUser])],  //引入了user实体providers:[UsersService],controllers:[UsersController]
})
export class UsersModule {}

创建provider服务

import { Injectable } from "@nestjs/common";
import { InjectRepository } from "@nestjs/typeorm";
import { newUser } from "./user.entity";
import { DeleteResult, Repository } from "typeorm";@Injectable()
export class UsersService{constructor(@InjectRepository(newUser) private usersRepository:Repository<newUser>){}//待完善的一系列操作数据库的方法
}

创建controller服务

import { Body, Controller, Delete, Get, Param, Post } from "@nestjs/common";
import { UsersService } from "./users.service";
import { User } from "./interface/users.interface";@Controller("users")
export class UsersController{constructor(private usersService:UsersService){}@Get()getAllUsers(){return this.usersService.findAll()}@Get('/:id')getUserById(@Param('id') id:number){return this.usersService.getUserById(id)}@Delete("/:id")deleteById(@Param('id') id:number){return this.usersService.remove(id)}@Post('')addUserData(@Body() user:User){console.log(user,'add')return this.usersService.addUser(user)}
}

至此创建文件就结束了,此时我们可以到数据库看到多了一张表new_user

在这里插入图片描述

接下来我们就来进行数据的crud

增删改查

业务代码我们要写在service文件中

查:

findAll():Promise<newUser[]>{return this.usersRepository.find();
}

如果里面没有任何数据,那么返回的就是空,这里我已经增加了相关数据,所以会有返回结果

在这里插入图片描述

增:

async addUser(user:newUser):Promise<string>{/*** 数据库里面找不到这个数据才新增*/const isNotExist = (await this.usersRepository.find()).every(item => item.firstName != user.firstName && item.lastName != user.lastName)if(isNotExist){await this.usersRepository.save(user)console.log("🚀 ~ file: users.service.ts:28 ~ UsersService ~ addUser ~ data:",'ok')return "ok"}else{return "不允许重复添加数据"}}

这里是post请求,我们需要借助postman等来进行操作

在这里插入图片描述

在这里插入图片描述

非常好,我们成功新增了一条数据…

那如果我们增加一条已经存在的数据,那结果会怎样呢?我们可以试试,因为我这里是不允许重名的,所以无法新增成功,重名会报错,大家可以根据自己的实际业务需求进行操作

再次添加白眉鹰王,返回提示重复,数据库也没变化

在这里插入图片描述
在这里插入图片描述

删:

async remove(id:number):Promise<number>{const data = await this.usersRepository.delete(id)console.log(data,'delete-data')return data.affected;
}

根据id删了id为6的白眉,再次查询,数据库就少了这条数据,删除成功!!!
在这里插入图片描述
在这里插入图片描述

完整的代码如下

import { Injectable } from "@nestjs/common";
import { InjectRepository } from "@nestjs/typeorm";
import { newUser } from "./user.entity";
import { DeleteResult, Repository } from "typeorm";@Injectable()
export class UsersService{constructor(@InjectRepository(newUser) private usersRepository:Repository<newUser>){}findAll():Promise<newUser[]>{return this.usersRepository.find();}getUserById(id:number):Promise<newUser | null>{return this.usersRepository.findOneBy({id})}async remove(id:number):Promise<number>{const data = await this.usersRepository.delete(id)console.log(data,'delete-data')return data.affected;}async addUser(user:newUser):Promise<string>{/*** 数据库里面找不到这个数据才新增*/const isNotExist = (await this.usersRepository.find()).every(item => item.firstName != user.firstName && item.lastName != user.lastName)if(isNotExist){await this.usersRepository.save(user)console.log("🚀 ~ file: users.service.ts:28 ~ UsersService ~ addUser ~ data:",'ok')return "ok"}else{return "不允许重复添加数据"}}
}

这样我们就实现了,nestjs整合mysql数据库,实现数据crud了,以后再也不用让求着让后端帮忙改接口了…

更多后续精彩内容,请关注本系列的动态

请添加图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/333902.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

javaweb基础----JDBC(一)

一、什么是JDBC JDBC全称为Java数据库连接(Java Database Connectivity),是一套用于执行SQL语句的Java API。应用程序可以通过这套API连接到关系型数据库&#xff0c;并使用SQL语句完成对数据中数据的查询、增加、更新和删除等操作。 JDBC在应用程序与数据库之间起到了一个桥…

C语言KR圣经笔记 5.6指针数组;指针的指针

5.6 指针数组&#xff1b;指针的指针 因为指针本身也是变量&#xff0c;所以它们也能像其他变量一样保存在数组里面。我们写个程序来说明&#xff0c;该程序将一些文本行按照字母顺序排列&#xff0c;算是 UNIX 程序 sort 的精简版本。 在第三章中&#xff0c;我们介绍了对一…

首个!美创科技助力大型能源央企数据安全能力成熟度评估及规划建设

2024开年&#xff0c;再传捷报。美创科技首个核电行业数据安全治理项目&#xff0c;也是首个大型能源央企数据安全治理项目落地&#xff01;美创数据安全治理咨询团队&#xff0c;助力用户完成数据安全现状评估、数据安全体系标准设计和落地、数据分类分级落地试点、数据安全三…

性能分析与调优: Linux 使用 iperf3 进行TCP网络吞吐量测试

目录 一、实验 1.环境 2.TCP网络吞吐量的微观基准测试 二、问题 1.iperf参数有哪些 2.iperf如何二进制安装 一、实验 1.环境 &#xff08;1&#xff09;主机 表1-1 主机 主机架构组件IP备注prometheus 监测 系统 prometheus、node_exporter 192.168.204.18grafana监测…

Arduino类库封装编写-以超声波测距举例

目录 一、前言 二、类封装 1、创建头文件 2、创建源文件 3、条件编译说明 &#xff08;1&#xff09;头文件重复定义 &#xff08;2&#xff09;版本兼容性预处理 4、用户程序中使用封装的类 5、测试 三、将封装的类制作成库文件 1、创建SR04库文件目录 2、库文件中…

智能网联汽车网络安全测试:渗透测试,模糊测试详细讲解

1. 基础知识 1.1 智能网联汽车架构 车内网络系统架构 随着智能网联汽车电子系统的复杂化&#xff0c;电子电气架构&#xff08; Electrical/Electronic Architecture&#xff0c; EEA &#xff09;由分布式向集中式架构演进&#xff0c;如图 2.1 所示。 在汽车 EEA 演进的…

构建免费的Dokan和WooCommerce构建线上课程市场在线销售数字课程

我们知道创建良好的学习说明和材料很困难。但当涉及到销售时&#xff0c;就变得更加困难。如果您无法出售您的课程&#xff0c;那么没有什么比这更令人沮丧的了。 幸运的是&#xff0c;如果您使用的是 WordPress 网站&#xff0c;那么您可以非常轻松且免费地完成此操作。借助L…

统信UOS虚拟机安装VirtualBox扩展使用USB功能

为什么要安装VirtualBox扩展包&#xff1f; 安装 Oracle VM VirtualBox 扩展包的原因是&#xff0c;它提供了对 USB 2.0、USB 3.0、远程桌面协议 VRDP&#xff08;VirtualBox Remote Desktop Protocol&#xff09;等实用功能的支持&#xff0c;以增强 VirtualBox 的功能。这些…

JavaScript高级程序设计读书记录(八):对象的使用及创建

ECMA-262 将对象定义为一组属性的无序集合。严格来说&#xff0c;这意味着对象就是一组没有特定顺序的 值。对象的每个属性或方法都由一个名称来标识&#xff0c;这个名称映射到一个值。正因为如此&#xff08;以及其他还未 讨论的原因&#xff09;&#xff0c;可以把 ECMAScri…

区块链金融科技:技术融合与挑战应对【文末送书-16】

文章目录 前言一.区块链与金融科技的融合&#xff1a;革新金融格局的技术之光1.1区块链技术简介1.2 区块链在金融科技中的应用 二.智能合约2.1 去中心化金融&#xff08;DeFi&#xff09;2.2区块链对金融科技的影响2.3数据安全性 三.区块链与金融科技【文末送书-16】3.1 粉丝福…

计算机配件杂谈-鼠标

目录 基础知识鼠标的发展鼠标的左右手鼠标的显示样式鼠标的移动和可见性移动可见性 现在的我们的生活工作都基本上离不开电脑了&#xff0c;不管是你平时玩玩游戏&#xff0c;上班工作等等&#xff1b; 今天将关于鼠标的一些小的技巧分享出来&#xff0c;共勉&#xff01; 基础…

系列三十五、获取Excel中的总记录数

一、获取Excel中的总记录数 1.1、概述 使用EasyExcel开发进行文件上传时&#xff0c;通常会碰到一个问题&#xff0c;那就是Excel中的记录数太多&#xff0c;使用传统的方案进行文件上传&#xff0c;很容易就超时了&#xff0c;这时可以通过对用户上传的Excel中的数量进行限制…