Nestjs联合Typeorm操作Mysql数据库

该博客围绕MySQL数据库单表及关联表的增删改查操作展开。先介绍单张表增删改查的项目创建、框架搭建及代码修改;接着阐述一对一、一对多(多对一)、多对多关联表增删改查的操作,包括创建新表、模块注入等,最后说明在service里进行相关代码编写。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

单张表增删改查

创建项目

// 安装脚手架(只需要安装一次,因为这个是全局的)
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 {
    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,
    }),
    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/user2
  async 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) {
   
      
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

萧寂173

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值