【问题标题】:MySQL Foreign Keys ALTER statementMySQL 外键 ALTER 语句
【发布时间】:2014-08-21 18:34:05
【问题描述】:

MySQL 5.6.16 两张桌子。更改表 1,使其具有表 2 主键的外键。 SQL 错误 1215。

如果我删除表 1 并将外键约束合并到构建中,它会很好地接受约束。只有在创建后更改表才会导致问题。

有什么想法吗?下面是编写 alter 语句的两次尝试,然后是创建脚本。

    ALTER TABLE c_users ADD FOREIGN KEY fk_user_prof_position_tid(professional_position_tid) REFERENCES d_taxonomy(tid);
    ALTER TABLE c_users ADD CONSTRAINT fk_user_prof_position_tid FOREIGN KEY (professional_position_tid) REFERENCES d_taxonomy(tid);

    CREATE TABLE c_users (
    user_id INT(11) NOT NULL AUTO_INCREMENT COMMENT 'Primary, auto-generated key',
    professional_position_tid INT(11),
    ...
    PRIMARY KEY (user_id)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    CREATE INDEX i_user_id ON c_users (user_id) USING BTREE;

    CREATE TABLE d_taxonimy (
    tid INT(11) NOT NULL COMMENT '',
    ...
    PRIMARY KEY (tid)
    ) ENGINE=InnoDB DEFAULT CHARSET=utf8;
    CREATE INDEX i_tid ON d_taxonimy (tid) USING BTREE;

【问题讨论】:

  • show engine innodb status 将有更多关于 Fk 错误的详细信息,该错误被隐藏在输出下方约 1/2 处。它会告诉你更改被拒绝的确切原因。

标签: mysql sql


【解决方案1】:

错别字:

ALTER TABLE [...snip...] REFERENCES d_taxonomy(tid);
                                         ^----

CREATE TABLE d_taxonimy (
                    ^----

另外,如果您按该顺序运行语句,则无法更改尚不存在的表,或在外域/表尚不存在时创建外键。

【讨论】:

  • 在创建后肯定会运行 alter 语句。改正错字很管用,让我感觉自己聪明如磐石。谢谢!
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2015-06-30
  • 2018-04-27
  • 2019-01-02
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多