如何在 NestJS 中使用 TypeORM 实现多数据库连接配置

2024-01-09 00:36

本文主要是介绍如何在 NestJS 中使用 TypeORM 实现多数据库连接配置,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

当你打算在一个 NestJS 应用中操作多个数据库时,TypeORM 提供了优雅而强大的解决方案。在本教程中,我们将一步步了解如何在 NestJS 项目中配置 TypeORM 以使用多个数据库。

实现步骤

一、创建 NestJS 项目

如果你还没有一个 NestJS 项目,请使用以下命令创建一个新项目:

nest new multi-database-app

进入项目后,我们准备好基础设施。

二、安装 TypeORM 和数据库驱动

请确保你已安装了 TypeORM 并添加了对你将使用的数据库的支持。例如,如果你使用 MySQL 和 PostgreSQL,则需要安装它们的驱动:

npm install @nestjs/typeorm typeorm mysql pg

三、创建数据库配置文件

在项目的根目录下,创建两个配置文件 ormconfig.mysql.jsonormconfig.postgres.json,用于存放两个不同数据库的配置。

ormconfig.mysql.json 示例:

{"name": "mysqlConnection","type": "mysql","host": "localhost","port": 3306,"username": "your_mysql_username","password": "your_mysql_password","database": "your_mysql_db","entities": ["dist/**/*.entity{.ts,.js}"],"synchronize": true
}

ormconfig.postgres.json 示例:

{"name": "postgresConnection","type": "postgres","host": "localhost","port": 5432,"username": "your_postgres_username","password": "your_postgres_password","database": "your_postgres_db","entities": ["dist/**/*.entity{.ts,.js}"],"synchronize": true
}

确保配置文件对应到正确的数据库和认证信息。entities 配置了实体位置,方便 TypeORM 自动加载。

四、设置多个数据库连接

修改 app.module.ts 来包含多个数据库连接:

import { Module } from '@nestjs/common';
import { TypeOrmModule } from '@nestjs/typeorm';
import * as mysqlConfig from './ormconfig.mysql.json';
import * as postgresConfig from './ormconfig.postgres.json';@Module({imports: [TypeOrmModule.forRoot(mysqlConfig),TypeOrmModule.forRoot(postgresConfig)],
})
export class AppModule {}

我们使用 TypeOrmModule.forRoot() 方法两次,分别传入两个数据库的配置。

五、创建数据库实体

根据你的业务需求为每个数据库创建实体类。这里我们假设 MySQl 用于存储 User 实体,而 PostgreSQL 存储 Post 实体。

src 目录下创建 user.entity.ts

import { Entity, PrimaryGeneratedColumn, Column } from 'typeorm';@Entity()
export class User {@PrimaryGeneratedColumn()id: number;@Column()name: string;
}

src 目录下创建 post.entity.ts

import { Entity, PrimaryGeneratedColumn, Column } from 'typeorm';@Entity()
export class Post {@PrimaryGeneratedColumn()id: number;@Column()title: string;@Column()content: string;
}

确保这些实体类遵循 TypeORM 的装饰器模式进行定义。

六、在服务中注入并使用多个数据库连接

要在服务中使用不同的数据库连接,我们需要为每个数据库创建一个特殊的符号,让 NestJS 可以识别并注入正确的 Repository。

首先,创建两个服务类,users.service.ts(用于操作 MySQL 数据库的 User 实体)和 posts.service.ts(用于操作 PostgreSQL 数据库的 Post 实体)。

  1. UsersService - 使用 MySQL

    src 目录下创建 users.service.ts

    import { Injectable } from '@nestjs/common';
    import { InjectRepository } from '@nestjs/typeorm';
    import { User } from './user.entity';
    import { Repository } from 'typeorm';@Injectable()
    export class UsersService {constructor(@InjectRepository(User, 'mysqlConnection')private readonly userRepository: Repository<User>,) {}// 添加用户的逻辑async createUser(userInfo: CreateUserDto): Promise<User> {const user = this.userRepository.create(userInfo);return this.userRepository.save(user);}// 其他 CRUD 操作...
    }

    这里使用 InjectRepository 装饰器和连接名 mysqlConnection 来注入特定的 Repository。

  2. PostsService - 使用 PostgreSQL

    src 目录下创建 posts.service.ts

    import { Injectable } from '@nestjs/common';
    import { InjectRepository } from '@nestjs/typeorm';
    import { Post } from './post.entity';
    import { Repository } from 'typeorm';@Injectable()
    export class PostsService {constructor(@InjectRepository(Post, 'postgresConnection')private readonly postRepository: Repository<Post>,) {}// 添加文章的逻辑async createPost(postData: CreatePostDto): Promise<Post> {const post = this.postRepository.create(postData);return this.postRepository.save(post);}// 其他 CRUD 操作...
    }

    类似地,这里使用 InjectRepository 装饰器和连接名 postgresConnection 来注入 Post 的 Repository。

七、实现服务逻辑和 CRUD 示例

现在我们已经有了操作两个数据库的服务,我们可以在每个服务类中添加 CRUD 方法,实现数据的增删改查。

  1. 创建 DTOs (Data Transfer Objects)

    对于每个 CRUD 操作,建议使用 DTOs 来传递数据。在 src 目录下创建 create-user.dto.tscreate-post.dto.ts 文件定义 DTOs。

    create-user.dto.ts 示例:

    export class CreateUserDto {readonly name: string;
    }

    create-post.dto.ts 示例:

    export class CreatePostDto {readonly title: string;readonly content: string;
    }
  2. 完成 CRUD 操作

    UsersServicePostsService 服务中定义 CRUD 操作。我们已经为 UsersService 定义了 createUser 方法,现在让我们添加查询所有用户的方法:

    // users.service.tsasync getUsers(): Promise<User[]> {return this.userRepository.find();
    }

    类似地,在 PostsService 添加查询所有文章的方法:

    // posts.service.tsasync getPosts(): Promise<Post[]> {return this.postRepository.find();
    }

结语

现在你已经了解了在 NestJS 应用中使用 TypeORM 设置和操作多个数据库的完整流程。通过上述步骤,你不仅可以连接单一数据库,而且还能够灵活地同步操作多个数据库。

我们鼓励你根据自己的项目需求进一步探索 TypeORM 的高级特性,例如实体关系、事务管理、订阅功能和更多数据持久化的策略,从而充分利用异构数据库环境带来的优势。这将大大提升你的 NestJS 应用程序的可扩展性和健壮性。

这篇关于如何在 NestJS 中使用 TypeORM 实现多数据库连接配置的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

Java实现字符串大小写转换的常用方法

《Java实现字符串大小写转换的常用方法》在Java中,字符串大小写转换是文本处理的核心操作之一,Java提供了多种灵活的方式来实现大小写转换,适用于不同场景和需求,本文将全面解析大小写转换的各种方法... 目录前言核心转换方法1.String类的基础方法2. 考虑区域设置的转换3. 字符级别的转换高级转换

使用Python将PDF表格自动提取并写入Word文档表格

《使用Python将PDF表格自动提取并写入Word文档表格》在实际办公与数据处理场景中,PDF文件里的表格往往无法直接复制到Word中,本文将介绍如何使用Python从PDF文件中提取表格数据,并将... 目录引言1. 加载 PDF 文件并准备 Word 文档2. 提取 PDF 表格并创建 Word 表格

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

Python使用Matplotlib和Seaborn绘制常用图表的技巧

《Python使用Matplotlib和Seaborn绘制常用图表的技巧》Python作为数据科学领域的明星语言,拥有强大且丰富的可视化库,其中最著名的莫过于Matplotlib和Seaborn,本篇... 目录1. 引言:数据可视化的力量2. 前置知识与环境准备2.1. 必备知识2.2. 安装所需库2.3

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Linux内核定时器使用及说明

《Linux内核定时器使用及说明》文章详细介绍了Linux内核定时器的特性、核心数据结构、时间相关转换函数以及操作API,通过示例展示了如何编写和使用定时器,包括按键消抖的应用... 目录1.linux内核定时器特征2.Linux内核定时器核心数据结构3.Linux内核时间相关转换函数4.Linux内核定时

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp