Mysql表创建外键报错解决方案

Raizel ·
更新时间:2024-11-11
· 616 次阅读

数据库表A:

CREATE TABLE task_desc_tab ( id INT(11) PRIMARY KEY NOT NULL COMMENT '自增主键' AUTO_INCREMENT, <strong>taskname</strong> VARCHAR(200) NOT NULL COMMENT '任务名字', sqlname VARCHAR(20) NOT NULL COMMENT 'sql文件名字', params VARCHAR(5000) NOT NULL COMMENT '任务参数,格式为一个JSON字符串', updatetime TIMESTAMP DEFAULT CURRENT_TIMESTAMP COMMENT '更新时间', detail VARCHAR(3000) COMMENT '任务一些描述信息,只是备注信息作用' ) ENGINE = InnoDB DEFAULT CHARSET = utf8;

数据库B:

CREATE TABLE exec_plan_tab ( id INT(11) PRIMARY KEY NOT NULL AUTO_INCREMENT, <strong>taskname</strong> VARCHAR(200) NOT NULL, startdate DATE NOT NULL, enddate DATE NOT NULL, updatetime TIMESTAMP DEFAULT CURRENT_TIMESTAMP, CONSTRAINT exec_plan_tab_task_desc_tab_taskname_fk FOREIGN KEY (taskname) REFERENCES task_desc_tab (taskname) ) ENGINE = InnoDB DEFAULT CHARSET = utf8;

目标:创建表使得表B中的taskname为外键,参考表A中的taskname字段,创建表发现报错如下:

[2018-07-19 15:02:29] [HY000][150] Create table 'daxin/#sql-5d_30' with foreign key constraint failed. There is no index in the referenced table where the referenced columns appear as the first columns.
[2018-07-19 15:02:29] [HY000][1215] Cannot add foreign key constraint
[2018-07-19 15:02:29] [HY000][1215] Cannot add foreign key constraint 

经过排查找到问题原因: 表A中的taskname必须使用UNIQUE字段修饰,这样保证记录唯一性,当表B参考时候不会出现歧义。

您可能感兴趣的文章:mysql外键基本功能与用法详解mysql外键的三种关系实例详解Mysql数据库中数据表的优化、外键与三范式用法实例分析MySQL创建数据表并建立主外键关系详解MySQL外键约束常见操作方法示例【查看、添加、修改、删除】MySQL无法创建外键的原因及解决方法MySQL删除有外键约束的表数据方法介绍MySQL删除表的时候忽略外键约束的简单实现MySQL添加外键时报错:1215 Cannot add the foreign key constraint的解决方法MySQL使用外键实现级联删除与更新的方法



外键 解决方案 mysql表 Mysql

需要 登录 后方可回复, 如果你还没有账号请 注册新账号