主页 > 知识库 > Mysql表创建外键报错解决方案

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

热门标签:地图标注客户付款 许昌外呼增值业务线路 宜宾全自动外呼系统厂家 临沂做地图标注 申请400电话电话价格 新乡智能外呼系统好处 广东400企业电话申请流程 咸阳防封电销卡 石家庄400电话办理公司

数据库表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导入csv的4种报错的解决方法
  • 解决navicat远程连接mysql报错10038的问题
  • Navicat Premiun远程连接MySQL报错10038解决方案
  • 解决Navicat Premium 连接 MySQL 8.0 报错"1251"的问题分析
  • mysql 主从复制如何跳过报错
  • IDEA链接MySQL报错08001和连接成功后不显示表的问题及解决方法
  • MySQL数据库导入导出数据之报错解答实例讲解

标签:贵州 台湾 北京 阜新 日照 合肥 镇江 鹰潭

巨人网络通讯声明:本文标题《Mysql表创建外键报错解决方案》,本文关键词  Mysql,表创,建外,键,报错,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《Mysql表创建外键报错解决方案》相关的同类信息!
  • 本页收集关于Mysql表创建外键报错解决方案的相关信息资讯供网民参考!
  • 推荐文章