zoukankan      html  css  js  c++  java
  • 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参考时候不会出现歧义。

  • 相关阅读:
    naotu.baidu.com 非常棒的脑图在线工具
    编程常用英语词汇大全
    我的总结,编程人生
    排序箭头,升序,降序简单实现
    jquery网页倒计时效果,秒杀,限时抢购!
    echarts入门,5分钟上手写ECharts的第一个图表
    严谨的程序案例Api
    github Travis CI 持续集成
    Cmake使用
    Linxu安装Lamp环境
  • 原文地址:https://www.cnblogs.com/leodaxin/p/9336140.html
Copyright © 2011-2022 走看看