作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《Effective Java》独家解析》专栏作者。
超键、候选键、主键和外键是数据库设计中的重要概念,它们在保证数据的一致性、完整性和避免数据冗余方面发挥着重要作用。下面将逐一解释这些概念,并给出相应的例子。
超键是数据库表中能够唯一标识每条记录的属性集合。它可以是一个列,也可以是多个列的组合。超键的作用是确保数据表中的每一行数据都可以被唯一地识别。
例子:在一个学生信息表中,学生的学号
、学号+姓名
都可以作为超键,因为它们都能唯一标识表中的一条记录。
候选键是最小的超键,也就是说,你不能从候选键中再移除任何属性而不影响其唯一标识记录的能力。一个表可以有一个或多个候选键。
例子:继续上面的学生信息表例子,学号
是一个候选键,因为它本身就可以唯一标识表中的记录,而且不能再分割成更小的部分。
主键是从一个或多个候选键中选出的一个,用于唯一标识表中的每条记录。每个表只能有一个主键。主键的值不能重复,也不能为NULL。
例子:在上述的学生信息表中,如果我们选择学号
作为主键,那么每个学生的学号都必须是唯一的。
外键是一个表中的字段,它是另一个表的主键。外键用于建立两个表之间的关联,确保引用的数据的完整性。
例子:假设有一个课程表
,其中包含课程ID
和课程名称
,以及一个选课表
,包含学号
和课程ID
。这里的课程ID
在选课表
中就是一个外键,它引用了课程表
中的主键。
接下来,我将根据这些概念出 6 道相关的选择题,并在最后给出答案和详细讲解。
表A
的某字段是表B
的主键,那么这个字段在表A
中称为: