Nestjs联合Typeorm操作Mysql数据库

2023-12-10 16:12

本文主要是介绍Nestjs联合Typeorm操作Mysql数据库,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

创建项目

// 安装脚手架(只需要安装一次,因为这个是全局的)
npm i -g @nestjs/cli
// 创建项目
nest new project-name
// (该过程有个选择包管理工具的,我选的yarn)

启动项目

yarn run start:dev
// 可以在浏览器访问localhost:3000  输出helloWorld

安装typeorm,mysql2和@nestjs/typeorm

// 安装依赖
yarn add --save @nestjs/typeorm typeorm mysql2
// @nestjs/typeorm这个本人运行上面命令一直安装不上,只好单独安装一下就成功了(yarn add @nestjs/typeorm)

创建实体模块

nest g res user2

连接数据库(app.module.ts)

import { Module } from '@nestjs/common';
import { AppController } from './app.controller';
import { AppService } from './app.service';
import { TypeOrmModule } from '@nestjs/typeorm';
import { UserModule } from './user/user.module';
import { User2Module } from './user2/user2.module';
@Module({imports: [TypeOrmModule.forRoot({type: 'mysql',host: 'localhost',port: 3306,username: 'root',password: 'admin',database: 'shop',autoLoadEntities: true,synchronize: true,}),UserModule,User2Module,],controllers: [AppController],providers: [AppService],
})
export class AppModule {}

上面将框架搭建完成了,后面都是对代码的修改

/src/user2/entities/user2.entity.ts

import { Entity, Column, PrimaryGeneratedColumn } from 'typeorm';@Entity()
export class User2 {@PrimaryGeneratedColumn()id: number;@Column()firstName: string;@Column()lastName: string;@Column({ default: true })isActive: boolean;
}

/src/user2/user2.module.ts

import { Module } from '@nestjs/common';
import { User2Service } from './user2.service';
import { User2Controller } from './user2.controller';
// 引入实体
import { User2 } from './entities/user2.entity';
// 引入orm框架
import {TypeOrmModule} from '@nestjs/typeorm'
@Module({imports:[TypeOrmModule.forFeature([User2])],controllers: [User2Controller],providers: [User2Service],
})
export class User2Module {}

到这一步,运行项目会发现数据库多出来一张user2的表,表字段和user2.entity.ts一一对应
接下来三个文件内都是逻辑代码

/src/user2/dto/create-user2.dto.ts

// 这里在添加数据用上了
export class CreateUser2Dto {firstName: string;lastName: string;isActive: boolean;
}

/src/user2/user2.controller.ts

import {Controller,Get,Post,Body,Patch,Param,Delete,Query,DefaultValuePipe,ParseIntPipe,
} from '@nestjs/common';
import { User2Service } from './user2.service';
import { CreateUser2Dto } from './dto/create-user2.dto';
import { UpdateUser2Dto } from './dto/update-user2.dto';@Controller('user2')
export class User2Controller {constructor(private readonly user2Service: User2Service) {}@Post() // 这里添加数据使用了apifox,调至post接口,Body-json类型,将添加的字段依次输入即可,直接发请求 http://localhost:3000/user2async create(@Body() createUser2Dto: CreateUser2Dto) {const res = await this.user2Service.create(createUser2Dto);if (res.generatedMaps.length > 0) {return {success: '添加成功',};} else {error: '添加失败';}return this.user2Service.create(createUser2Dto);}// 查询所有@Get()findAll(@Query('current', new DefaultValuePipe(1), ParseIntPipe) current: number, // 页数,默认值为1,int类型@Query('pagesize', new DefaultValuePipe(15), ParseIntPipe) pagesize: number, // 每页条数,默认值15) {// 传入当前页数,number类型的return this.user2Service.findAll(current, pagesize);}// 查询单条信息@Get(':id')findOne(@Param('id', ParseIntPipe) id: number) {// 将id类型转换为int类型限制为number类型return this.user2Service.findOne(+id);}// 更新(修改数据) 这里修改数据使用了apifox,调至post接口,Body-json类型,将添加的字段依次输入即可,直接发请求 http://localhost:3000/user2/3@Patch(':id')async update(@Param('id') id: string,@Body() updateUser2Dto: UpdateUser2Dto,) {const user = await this.user2Service.findOne(+id);if (user === null) {return {error: '没有此用户,暂时无法修改',};}const res = await this.user2Service.update(+id, updateUser2Dto);if (res.affected > 0) {return {success: '修改成功',};} else {error: '修改失败';}}// 根据id删除单个用户@Delete(':id')async remove(@Param('id') id: number) {// 先查询到这个用户(这里直接调用根据id查询用户的方法)const user = await this.user2Service.findOne(id); // 在findOne这个方法里面的findOne是使用了promise,因此这里需要异步一下if (user === null) {return { error: '删除的用户不存在' };}const res = this.user2Service.remove(+id);if ((await res).affected > 0) {return {success: '删除成功',};} else {error: '删除失败';}}
}

src/user2/user2.service.ts

import { Injectable } from '@nestjs/common';
import { CreateUser2Dto } from './dto/create-user2.dto';
import { UpdateUser2Dto } from './dto/update-user2.dto';
import { InjectRepository } from '@nestjs/typeorm';
// 1.导入实体
import { User2 } from './entities/user2.entity';
// 2.导入依赖注入
import { Repository } from 'typeorm';
@Injectable()
export class User2Service {// 3.需要对数据库进行操作,这里需要进行依赖注入constructor(@InjectRepository(User2)private user2Repoitory: Repository<User2>,) {}// 新增数据(这里需要用到dto层进行逻辑处理)create(createUser2Dto: CreateUser2Dto) {return this.user2Repoitory.insert(createUser2Dto);}// 查询数据findAll(current = 1, pagesize = 15) {// 查询所有的逻辑代码()(访问localhost:3000/user2)// return this.user2Repoitory.findAndCount();// 分页查询的代码return this.user2Repoitory.findAndCount({skip: (current - 1) * pagesize, // 跳过多少页take: pagesize, // 当前页数});}// 根据id查询findOne(id: number) {// 根据id查询用户信息// return this.user2Repoitory.findOneBy({ id });// 也可以使用findone查询,这个查询毕竟灵活return this.user2Repoitory.findOne({ where: { id } }); // 里面放查询条件}// 更新(修改数据)update(id: number, updateUser2Dto: UpdateUser2Dto) {// 根据id修改数据return this.user2Repoitory.update(id,updateUser2Dto);}// 根据id删除用户remove(id: number) {return this.user2Repoitory.delete(id);}
}

这篇关于Nestjs联合Typeorm操作Mysql数据库的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/477600

相关文章

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

MySQL分库分表的实践示例

《MySQL分库分表的实践示例》MySQL分库分表适用于数据量大或并发压力高的场景,核心技术包括水平/垂直分片和分库,需应对分布式事务、跨库查询等挑战,通过中间件和解决方案实现,最佳实践为合理策略、备... 目录一、分库分表的触发条件1.1 数据量阈值1.2 并发压力二、分库分表的核心技术模块2.1 水平分

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

sysmain服务可以禁用吗? 电脑sysmain服务关闭后的影响与操作指南

《sysmain服务可以禁用吗?电脑sysmain服务关闭后的影响与操作指南》在Windows系统中,SysMain服务(原名Superfetch)作为一个旨在提升系统性能的关键组件,一直备受用户关... 在使用 Windows 系统时,有时候真有点像在「开盲盒」。全新安装系统后的「默认设置」,往往并不尽编

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

Python从Word文档中提取图片并生成PPT的操作代码

《Python从Word文档中提取图片并生成PPT的操作代码》在日常办公场景中,我们经常需要从Word文档中提取图片,并将这些图片整理到PowerPoint幻灯片中,手动完成这一任务既耗时又容易出错,... 目录引言背景与需求解决方案概述代码解析代码核心逻辑说明总结引言在日常办公场景中,我们经常需要从 W

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp