📅  最后修改于: 2023-12-03 15:20:19.424000             🧑  作者: Mango
在关系型数据库中,每个表都有一个或多个列作为主键(Primary Key),用来唯一标识每一行数据。然而,在一些情况下,需要用多个列进行联合唯一标识。这时就需要使用复合键(Compound Key)。
复合键指的是由多个列作为主键的一种情况。也可以称之为联合主键(Composite Key)。使用复合键可以保证多列的组合值在整个表中唯一。
CREATE TABLE table_name (
column1 datatype,
column2 datatype,
...
PRIMARY KEY (column1, column2, ... )
);
上述 SQL 语句创建了一张表,其中 column1
和 column2
联合作为主键。这意味着在表中任意一行都不能有相同的 column1
和 column2
组合值。
使用复合键可以带来一些优点,如下所示:
使用复合键需要注意以下几点:
以下是一个使用了复合键的示例:
CREATE TABLE employee (
emp_id INT NOT NULL,
emp_name VARCHAR(50) NOT NULL,
emp_dept VARCHAR(50),
PRIMARY KEY (emp_id, emp_name)
);
上述 SQL 语句创建了一张 employee
表,其中 emp_id
和 emp_name
联合作为主键。这意味着在表中任意一行都不能有相同的 emp_id
和 emp_name
组合值。
在关系型数据库中,复合键是一种很常见的设计。它可以帮助我们更好地限制数据的插入和提高查询效率。在使用时需要注意其列的顺序和空值限制,以保证数据库的数据一致性和完整性。