NestJS:TypeORM 连接mysql数据库,增删改查

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDSClaw,2核4GB
简介: NestJS:TypeORM 连接mysql数据库,增删改查

一、安装数据库相关模块

pnpm add @nestjs/typeorm typeorm mysql

package.json

二、navicat创建nestjs_base数据库,创建products数据表,添加记录

创建nestjs数据库,创建products数据表

navicat:连接MySQL,创建库、表_snow@li的博客-CSDN博客

products表添加记录

mysql:使用终端操作数据库_snow@li的博客-CSDN博客

三、src/entities/products.entity.ts 创建实体

import { Column, Entity, PrimaryGeneratedColumn, BaseEntity } from 'typeorm';
// Column:列/字段
// Entity:实体
// PrimaryGeneratedColumn:创建一个主列,该值将使用自动增量值自动生成。 它将使用auto-increment /serial /sequence创建int列(取决于数据库)。 你不必在保存之前手动分配其值,该值将会自动生成。
// BaseEntity:继承基础实体类
@Entity()
// Products需要与数据表同名
export class Products extends BaseEntity {
  @PrimaryGeneratedColumn()
  id: number;
  @Column({type:'varchar', name: 'name'})
  name: string;
  @Column({type:'varchar', name: 'type'})
  type: string;
}

四、src/app.module.ts 连接数据库 nestjs_base

import { Module } from '@nestjs/common';
import { TypeOrmModule } from '@nestjs/typeorm';
import { ProductsModule } from './products/products.module';
@Module({
  imports: [
    TypeOrmModule.forRoot({ // 连接数据库
      type: 'mysql', // 数据库类型
      host: 'localhost', // 数据库ip地址
      port: 3306, // 端口
      username: 'root', // 登录名
      password: 'snowball', // 密码
      database: 'nestjs_base', // 数据库名称
      entities: [__dirname + '/**/*.entity{.ts,.js}'], // 扫描本项目中.entity.ts或者.entity.js的文件
      synchronize: true, // 定义数据库表结构与实体类字段同步(这里一旦数据库少了字段就会自动加入,根据需要来使用)
    }),
    ProductsModule // 加载子模块
  ],
  controllers: [],
  providers: [],
})
export class AppModule {}

五、src/products/products.service.ts

import { Injectable } from '@nestjs/common';
import { InjectRepository } from '@nestjs/typeorm';
import { Repository } from 'typeorm';
import { Products } from '../entities/products.entity';
@Injectable()
export class ProductsService {
    // 使用InjectRepository装饰器并引入Repository即可使用typeorm的操作
    constructor(
        @InjectRepository(Products)
        private readonly productsRepository: Repository<Products>,
    ) { }
    // 查询数据库产品数据
    // 获取所有用户数据列表(productsRepository.query()方法属于typeoram)
    async getList(): Promise<Products[]> {
        return await this.productsRepository.query('select * from products');
    }
}

六、src/products/products.controller.ts

import { Controller, Get, Post, Request, Query, Body, Param } from '@nestjs/common';
import { ProductsService } from './products.service';
import { Products } from '../entities/products.entity';
@Controller('products')
export class ProductsController {
    // this.productsService = new ProductsService() 等价于 constructor 方式
    constructor(private productsService: ProductsService){}
    // 通过数据库查询产品list
    @Get('list')
    getList(): Promise<Products[]> {
        return this.productsService.getList();
    }
}

七、src/products/products.module.ts

import { Module } from '@nestjs/common';
import { ProductsController } from './products.controller';
import { ProductsService } from './products.service';
import { TypeOrmModule } from '@nestjs/typeorm';
import { Products } from '../entities/products.entity';
@Module({
  imports:[TypeOrmModule.forFeature([Products])], // 导入并注册实体
  controllers: [ProductsController],
  providers: [ProductsService]
})
export class ProductsModule {}

八、访问接口地址

8.1、RESTClient访问接口地址,访问成功

8.2、浏览器地址访问,访问成功。

九、nestjs数据库products数据表,增删改查数据

9.1、src/products/products.service.ts

import { Injectable } from '@nestjs/common';
import { InjectRepository } from '@nestjs/typeorm';
import { Repository } from 'typeorm';
import { Products } from '../entities/products.entity';
@Injectable()
export class ProductsService {
    // 使用InjectRepository装饰器并引入Repository即可使用typeorm的操作
    constructor(
        @InjectRepository(Products)
        private readonly productsRepository: Repository<Products>,
    ) { }
    // 查询数据库产品数据
    // 获取所有用户数据列表(productsRepository.query()方法属于typeoram)
    async getList(): Promise<Products[]> {
        return await this.productsRepository.query('select * from products');
    }
    // 通过id查询产品
    async getProductById(id): Promise<Products> {
        return await this.productsRepository.findOne({where:{id: id}});
    }
    // 新增产品
    async addProduct(product): Promise<any> {
        return await this.productsRepository.insert(product);
    }
    // 更新产品
    async updateProduct(product): Promise<string> {
        let res = await this.productsRepository.update({ id: product.id }, product);
        if(res){
            return "更新成功"
        } else {
            return "更新失败"
        }
    }
    // 删除产品
    async delProduct(params): Promise<object> {
        let res = await this.productsRepository.delete({ id: params.id });
        if(res){
            return {
                code: 0,
                data: "",
                msg: "删除成功"
            }
        } else {
            return {
                code: 0,
                data: "",
                msg: "删除失败"
            }
        }
    }
}

9.2、src/products/products.controller.ts

import { Controller, Get, Post, Request, Query, Body, Param } from '@nestjs/common';
import { ProductsService } from './products.service';
import { Products } from '../entities/products.entity';
@Controller('products')
export class ProductsController {
    // this.productsService = new ProductsService() 等价于 constructor 方式
    constructor(private productsService: ProductsService){}
    // 通过数据库查询产品list
    @Get('list')
    getList(): Promise<Products[]> {
        return this.productsService.getList();
    }
    // 通过id查询产品
    @Get('getProductById')
    getProductById(@Query() query): Promise<Products> {
        let id:number = parseInt(query.id)
        return this.productsService.getProductById(id);
    }
    // 增加产品
    @Post('addProduct')
    addProduct(@Body() body): Promise<Products> {
        return this.productsService.addProduct(body);
    }
    // 更新产品
    @Post('updateProduct')
    updateProduct(@Body() body): Promise<string> {
        return this.productsService.updateProduct(body);
    }
    // 删除产品
    @Post('delProduct')
    delProduct(@Body() body): Promise<object> {
        return this.productsService.delProduct(body);
    }
}

9.3、测试:

通过id查询产品

新增产品

更新产品

删除产品

十、欢迎交流指正,关注我,一起学习。

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。 &nbsp; 相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情:&nbsp;https://www.aliyun.com/product/rds/mysql&nbsp;
相关文章
|
7月前
|
SQL 关系型数据库 MySQL
排除通过IP访问MySQL时出现的连接错误问题
以上步骤涵盖了大多数遇到远程连接 MySQL 数据库时出现故障情形下所需采取措施,在执行每个步骤后都应该重新尝试建立链接以验证是否已经解决问题,在多数情形下按照以上顺序执行将能够有效地排除并修复大多数基本链接相关故障。
487 3
|
7月前
|
SQL Java 关系型数据库
Java连接MySQL数据库环境设置指南
请注意,在实际部署时应该避免将敏感信息(如用户名和密码)硬编码在源码文件里面;应该使用配置文件或者环境变量等更为安全可靠地方式管理这些信息。此外,在处理大量数据时考虑使用PreparedStatement而不是Statement可以提高性能并防止SQL注入攻击;同时也要注意正确处理异常情况,并且确保所有打开过得资源都被正确关闭释放掉以防止内存泄漏等问题发生。
322 13
|
7月前
|
SQL 关系型数据库 MySQL
MySQL数据库连接过多(Too many connections)错误处理策略
综上所述,“Too many connections”错误处理策略涉及从具体参数配置到代码层面再到系统与架构设计全方位考量与改进。每项措施都需根据具体环境进行定制化调整,并且在执行任何变更前建议先行测试评估可能带来影响。
1624 11
|
7月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
702 11
|
8月前
|
存储 关系型数据库 MySQL
修复.net Framework4.x连接MYSQL时遇到utf8mb3字符集不支持错误方案。
通过上述步骤大多数情况下能够解决由于UTF-encoding相关错误所带来影响,在实施过程当中要注意备份重要信息以防止意外发生造成无法挽回损失,并且逐一排查确认具体原因以采取针对性措施解除障碍。
542 12
|
7月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
7月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
7月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1233 152
|
7月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。

推荐镜像

更多
下一篇
开通oss服务