TDSQL MySQL ERROR 1173 (42000):This table type requires a primary key报错处理

💡 原文中文,约1000字,阅读约需3分钟。
📝

内容提要

在TDSQL MySQL 5.7中,建表时必须设置主键,否则会报错。主键的必要性在于遵循MySQL规范和提升性能,缺少主键可能导致备机复制变慢,产生严重问题。解决方法包括通过ALTER TABLE或修改建表语句添加主键,并确保主键列值唯一且非空。

🎯

关键要点

  • 在TDSQL MySQL 5.7中,建表时必须设置主键,否则会报错。
  • 主键的必要性在于遵循MySQL规范和提升性能。
  • 缺少主键可能导致备机复制变慢,产生严重问题。
  • TDSQL中设置建表必须需要显式主键的参数为reject_table_no_pk。
  • 使用row格式的binlog复制时,缺少主键会导致更新或删除操作变慢。
  • 为避免主备延迟,TDSQL禁止创建无主键的表。
  • 解决方案包括通过ALTER TABLE语句或修改建表语句添加主键。
  • 主键列必须满足值唯一且非空的条件。
  • 推荐使用整数类型如INT、BIGINT作为主键的数据类型。
  • 若表中已有数据,需确保主键列无重复值,否则会报错Duplicate entry。
🏷️

标签

➡️

继续阅读