本文共 1282 字,大约阅读时间需要 4 分钟。
数据库表A的创建语句如下:
CREATE TABLE task_desc_tab ( id INT(11) PRIMARY KEY NOT NULL COMMENT '自增主键' AUTO_INCREMENT, taskname 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, taskname 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;
创建表时发现以下错误信息:
[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
字段上。为了确保表B中的外键约束能够正常工作,表A的taskname
字段必须使用UNIQUE
修饰。这样可以保证每个taskname
值的唯一性,避免在表B引入外键时出现歧义。
转载地址:http://oodfk.baihongyu.com/