MySQL 外键 ALTER 语句

标签 mysql sql

MySQL 5.6.16 两张 table 。更改表 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;

最佳答案

错别字:

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

CREATE TABLE d_taxonimy (
                    ^----

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

关于MySQL 外键 ALTER 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25433565/

相关文章:

php - symfony 第一次无法安装资源

sql - Oracle SQL Developer 如何默认为其他用户表?

MySQL 复制/同步 : purge from master but not from slave

mysql - 是否有最佳/有效的方法来比较多行的相似性/差异?

sql - Oracle中如何使用字符串选择表?

php - 数组导入MYSQL

sql - 验证 T-SQL 存储过程的可靠方法

mysql - 使用 MySQL 在大表上运行更新非常慢

mysql - 在 INSERT INTO 语句期间访问自动递增值

MySQL 允许在 WHERE 子句中没有 IN 或比较运算符的子查询。它是如何工作的?