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

吾爱主题 阅读:181 2024-04-01 23:49:55 评论:0

数据库表A:

?
1 2 3 4 5 6 7 8 9 10 11 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:

?
1 2 3 4 5 6 7 8 9 10 11 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参考时候不会出现歧义。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:https://www.cnblogs.com/leodaxin/p/9336140.html

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容