踩坑记录: nestjs使用typeorm连接MySQL

项目场景:

在nest项目中使用typeorm连接MySQL时,明明配置了TypeOrmModule.forRoot(),却在运行项目时始终报错


问题描述

会提示连不上db

ERROR [TypeOrmModule] Unable to connect to the database
ERROR [ExceptionHandler] ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client

原因分析:

问题在于Node(mysql)尚不支持MySQL 8的这种新的默认身份验证方法
参考:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
nestjs可以和typeorm配合使用typeorm是一个支持多种数据库的ORM框架,可以简化数据库的操作。下面是nestjs如何使用typeorm的步骤: 1. 安装typeorm和相应的数据库驱动,例如mysql, postgres等。可以使用npm命令进行安装: ``` npm install typeorm mysql ``` 2. 在nestjs中创建一个数据库模块,可以在模块中配置数据库连接等信息。例如: ```typescript import { Module } from '@nestjs/common'; import { TypeOrmModule } from '@nestjs/typeorm'; import { User } from './user.entity'; @Module({ imports: [ TypeOrmModule.forRoot({ type: 'mysql', host: 'localhost', port: 3306, username: 'root', password: 'password', database: 'test', entities: [User], synchronize: true, }), ], }) export class DatabaseModule {} ``` 3. 创建一个实体类,表示数据库中的一个表格。例如: ```typescript import { Entity, Column, PrimaryGeneratedColumn } from 'typeorm'; @Entity() export class User { @PrimaryGeneratedColumn() id: number; @Column() name: string; @Column() age: number; @Column() email: string; } ``` 4. 在nestjs的服务中使用typeorm进行数据库操作。例如: ```typescript import { Injectable } from '@nestjs/common'; import { InjectRepository } from '@nestjs/typeorm'; import { Repository } from 'typeorm'; import { User } from './user.entity'; @Injectable() export class UserService { constructor( @InjectRepository(User) private readonly userRepository: Repository<User>, ) {} async findAll(): Promise<User[]> { return this.userRepository.find(); } async create(user: User): Promise<User> { return this.userRepository.save(user); } } ``` 这样,nestjs就可以和typeorm配合使用进行数据库操作了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值