回答

收藏

超级键、候选键和主键

技术问答 技术问答 424 人阅读 | 0 人回复 | 2023-09-14

有没有好心的人可以通过以下简单的例子澄清我的问题,确定超键、候选键和主键?
8 G3 M$ X0 q- N0 v2 v% H4 K# C& u我知道有很多帖子和网站解释了它们之间的区别。但看起来所有都是通用定义。: ?$ c  Z0 P- }* c$ H
例子:
! r6 X& x5 E9 g7 N  P3 S9 ~Student (StudentNumber,FamilyName,Degree,Major,Grade,PhoneNumber)所以我可以从上面的例子中知道StudentNumber是主键。& [  m/ ^. g5 m: R" s
但是对于超级键,我有点困惑。哪些属性组合可以分组成超级键?
. K' v) ]! }! c, y7 K) X/ X至于候选密钥,我对给出的定义感到困惑,因为任何候选密钥都可以用作主密钥。, s9 b# R9 G' l  G  Z9 ^
这是否意味着像这样的属性?PhoneNumber是候选键,可以是主键(假设一个人PhoneNumber只属学生); u. J* ^' b2 [! i
感谢您的澄清!( S. `) T: B; g
                                                                " }+ q1 c5 ^: S
    解决方案:                                                                , I7 o2 J2 }* B+ [: b
                                                                综上所述,超级键是一组唯一的定义列,因为你不需要教科书的定义。7 A' v& z# X# ?
集合可以有一个或多个元素,一个表可以有多个超级键。通常,您可以通过功能依赖来完成此操作。: N0 g+ Q3 a! H( H% A
在你的例子中,我假设:
$ s3 B* s/ Y: K3 |& q) `StudentNumber    uniqueFamilyName     not uniqueDegree     not uniqueMajor      not uniqueGrade      not uniquePhoneNumber    not unique在这种情况下,超级键是包含学生编号的任何组合。! W7 f1 n! w+ p
所以下面是超级键
' r% K+ }+ p3 ~8 ~: u/ R; z: M( d8 UStudentNumberStudentNumber,FamilyNameStudentNumber,FamilyName,DegreeStudentNumber,FamilyName,Degree,MajorStudentNumber,FamilyName,Degree,Major,GradeStudentNumber,FamilyName,Degree,Major,Grade,PhoneNumberStudentNumber,DegreeStudentNumber,Degree,MajorStudentNumber,Degree,Major,GradeStudentNumber,Degree,Major,Grade,PhoneNumberStudentNumber,MajorStudentNumber,Major,GradeStudentNumber,Major,Grade,PhoneNumberStudentNumber,GradeStudentNumber,Grade,PhoneNumberStudentNumber,PhoneNumber假设,如果PhoneNumber是唯一的(这几天谁分享电话),所以下面也是超级键(除了上面列出的内容)。) Z+ X+ A/ |3 y. W. e& P4 G. l
PhoneNumberPhoneNumber,Grade,PhoneNumber,Major,GradePhoneNumber,Degree,Major,GradePhoneNumber,FamilyName,Degree,Major,GradePhoneNumber,MajorPhoneNumber,Degree,MajorPhoneNumber,FamilyName,Degree,MajorPhoneNumber,StudentNumber,FamilyName,Degree,MajorPhoneNumber,DegreePhoneNumber,FamilyName,DegreePhoneNumber,StudentNumber,FamilyName,DegreePhoneNumber,FamilyNamePhoneNumber,StudentNumber,FamilyName候选键只是最短的超键。回到超级键的第一个列表(即电话号码不是唯一的),最短的超级键是StudentNumber。, z% t5 v1 {% q* F+ ?, `
主键通常只是候选键。
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则