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。
➡️