mysql数据库的创建外键_Mysql表创建外键报错解决方案

数据库表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;

目标:创建表使得表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表创建外键报错解决方案

本文地址: http://www.cppcns.com/shujuku/mysql/345710.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值