【问题标题】:TypeORM throws QueryFailedError ER_TABLE_EXISTS_ERROR: Table 'courses' already exists in MySQLTypeORM 抛出 QueryFailedError ER_TABLE_EXISTS_ERROR: MySQL 中已经存在表'courses'
【发布时间】:2021-08-14 00:29:48
【问题描述】:

当我设置 typeORM synchronize:true 我得到一个 [ExceptionHandler] ER_TABLE_EXISTS_ERROR: Table 'courses' already exists +3ms QueryFailedError: ER_TABLE_EXISTS_ERROR: Table 'courses' already exists 错误, 但是当我制作synchronize:false 时,我没有得到那个错误。 但我需要使用synchronize:true 来获取数据库更改。 有什么办法可以解决这个问题?

【问题讨论】:

  • 嗯,这对开发有好处,但在生产中永远不要这样做synchronize: true,你会后悔的。

标签: mysql nestjs typeorm


【解决方案1】:

您可能需要刷新表缓存。例如:

DROP TABLE IF EXISTS `tablename` ;
FLUSH TABLES `tablename` ; /* or exclude `tablename` to flush all tables */
CREATE TABLE `tablename` ...

此外,如果您有该级别的权限,您可以尝试删除您的数据库,然后设置 synchronize: true

【讨论】:

  • @TuharRoy 如果我删除表,我会丢失数据库的所有记录吗?
  • 即使我编写迁移并生成 synchronize: falsemigration: true 我也收到了该错误,我也尝试了刷新
  • 是的,您将丢失所有记录。我建议你做的是导出你的数据库,然后试试这个。
猜你喜欢
  • 2020-10-07
  • 2018-08-13
  • 1970-01-01
  • 2021-09-04
  • 2021-07-16
  • 1970-01-01
  • 1970-01-01
  • 2019-02-03
  • 1970-01-01
相关资源
最近更新 更多