• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Mysql表创建外键报错解决方案
    POST TIME:2021-10-18 19:57

    数据库表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中 char 和 varchar的区别
    下一篇:解压版MYSQL中文乱码问题解决方案
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信