如何在不同的模式中设置指向 table 的外键约束?

How can I set a foreign key constraint pointing a table in a different schema?

我对 MySQL 语法比较陌生。我正在尝试建立一个具有不同模式的数据库。为了方便起见,我将代码分为两部分:

当要为 table 中指向另一个模式中的 table 的 ID 创建外键约束时,我得到

“错误代码:1824。无法打开引用的 table 'schema_a.table_a”。

实际上,我已经这样做了:

#First part
CREATE SCHEMA `schema_a`
USE `schema_a`;
CREATE TABLE `table_a`
(
    IDa INTEGER NOT NULL,
    ...
    PRIMARY KEY(`IDa`)
 )ENGINE=InnoDB, CHARSET=..., Collate=...;


CREATE SCHEMA `schema_b`
USE `schema_b`;
CREATE TABLE `table_b`
(
    IDb INTEGER NOT NULL,
    IDa INTEGER NOT NULL,
    ...
    PRIMARY KEY(`IDb`)
)ENGINE=InnoDB, CHARSET=..., Collate=...;

#Second part
USE `Schema_b`;
ALTER TABLE `table_b`
ADD CONSTRAINT `FK_IDa` FOREIGN KEY (`IDa`) REFERENCES `schema_a.table_a`(`IDa`) ON DELETE CASCADE ON UPDATE CASCADE;

我什至不确定创建外部外键在形式上是否正确。

有没有人有解决这个问题的建议? 谢谢!

`schema_a.table_a`表示一个标识符,即MySQL假设只有table名字是schema_a.table_a。您需要单独引用多部分标识符的每个部分,如 `schema_a`.`table_a`.

ALTER TABLE `table_b`
            ADD CONSTRAINT `FK_IDa`
                           FOREIGN KEY (`IDa`)
                                       REFERENCES `schema_a`.`table_a`
                                                  (`IDa`)
                                       ON DELETE CASCADE
                                       ON UPDATE CASCADE;

或者您可以在您的特定情况下不引用。