gpt4 book ai didi

mysql - 为什么主键不能包含空值?

转载 作者:可可西里 更新时间:2023-11-01 07:48:49 25 4
gpt4 key购买 nike

我读到 mysql 对主键设置了非空约束,但唯一键允许一个列有一个空值。那么为什么主键不也允许空值呢??

最佳答案

PRIMARY KEY 列等价于 UNIQUE 和 NOT NULL,默认是索引列。
它应该是唯一的,因为主键标识表中的行,因此 2 个不同的行不应具有相同的键。
此外,主键可以在其他表中用作 FOREIGN KEY,这就是为什么它不能为 NULL,以便其他表可以找到引用表中的行。

例如:

CREATE person{   
id INT PRIMARY KEY, -- equals UNIQUE NOT NULL
name VARCHAR(20)
};

CREATE family{
id INT PRIMARY KEY, -- equals UNIQUE NOT NULL
menber_id INT FOREIGN KEY REFERENCE person(id)
};

关于mysql - 为什么主键不能包含空值?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25701288/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com