繁体   English   中英

SQL DDL:创建递归表(MySQL)

[英]SQL DDL: Creating a recursive table (MySQL)

我正在尝试创建一个名为Subject的递归实体。 一个主题可以是另一个主题的先决条件,这就是为什么它是递归的。 这是我到目前为止的内容:

CREATE TABLE subject(
    subject_code CHAR(7),
    subject_desc VARCHAR(255) NOT NULL,
    no_of_units TINYINT UNSIGNED NOT NULL CHECK (no_of_units > 0 AND no_of_units < 13),
    prerequisite CHAR(7),
    PRIMARY KEY (subject_code),
    FOREIGN KEY (prerequisite) REFERENCES subject(subject_code)
)ENGINE=INNODB;

以上是创建递归表的正确方法吗?

是。

您真正需要的是与父主题相关的“父”列。 您的前提条件列可以解决问题。

您可以在此处查看示例。 这个想法总是一样的。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM