候选键候选键.PPT

  1. 1、本文档共85页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
候选键候选键

3-4-1 鍵限制條件 – 候選鍵 候選鍵(Candidate Keys)是一個超鍵,在每一個關聯表至少擁有一個候選鍵,不只滿足超鍵的唯一性,還需要滿足最小性,如下所示: 最小性(Minimality):最小屬性數的超鍵,在超鍵中沒有一個屬性可以刪除,否則將違反唯一性。 關聯表的候選鍵需要同時滿足唯一性和最小性,也就是說,候選鍵是最小屬性數的超鍵,所以單一屬性的超鍵一定是候選鍵。 以Students關聯表為例,在超鍵中符合條件的候選鍵,如下所示: (sid) (SSN) 3-4-1 鍵限制條件 – 候選鍵 候選鍵(Candidate Keys)的屬性如果不只一個,而是多個屬性的集合,稱為複合鍵(Composite Key)。 如Enrollment 選課關聯表 course_no 和 sid 都不符合唯一性,關聯表Enrollent的(course_no, sid) 屬性集合符合唯一性,它是一個超鍵刪除任何一個屬性都會違反唯一性,所以滿足最小性,因此,超鍵(course_no, sid) 是一個候選鍵,也是一個複合鍵。 C 003 CS204 B 001 CS001 B 002 CS101 A 001 CS101 grade Sid Course_no 3-4-1 鍵限制條件 – 主鍵 主鍵(Primary Key;PK)是關聯表各候選鍵的其中之一,而且只有一個。例如:Students關聯表的(sid)和(SSN)都是候選鍵,關聯表的主鍵就是這兩個候選鍵的其中之一。 因為關聯表可能擁有多個候選鍵,如何在眾多候選鍵挑選主鍵的原則如下所示: 不可為空值(Not Null) 永遠不會改變(Never Change),如sid和SSN 非識別值(Nonidentifying Value),如客戶編號 簡短且簡單的值(Brevity and Simplicity) 3-4-1 鍵限制條件 – 替代鍵 在候選鍵中不是主鍵的其他候選鍵稱為替代鍵(Alternate Keys),因為這些是可以用來替代主鍵的候選鍵。 以Students關聯表來說,(sid)和(SSN)是兩個候選鍵,因為(sid)是主鍵;(SSN)就是替代鍵。 3-4-1 鍵限制條件 – 外來鍵(說明) 外來鍵(Foreign Keys;FK)是關聯表的單一或多個屬性的集合,它的屬性值是參考到其他關聯表的主鍵,當然也可能參考同一個關聯表的主鍵。外來鍵和其他關聯表的主鍵是對應的,在關聯式資料庫扮演連接關聯表的膠水功能,如下圖所示: 3-4-1 鍵限制條件 – 外來鍵(特性) 外來鍵一定參考其他關聯表的主鍵,可以用來建立兩個關聯表間的連接。 外來鍵在關聯表內不一定是主鍵。 外來鍵和參考的主鍵屬於相同定義域,不過屬性名稱可以不同。 外來鍵和參考主鍵中的主鍵如果是單一屬性;外來鍵就是單一屬性,主鍵是屬性集合;外來鍵一樣也是屬性集合。 外來鍵可以是空值NULL。 3-4-1 鍵限制條件 – 外來鍵(特性) 外來鍵可以參考同一個關聯表的主鍵。 如 Employees 關聯表的 boss 屬性是一個外來鍵,參考同一個關聯表的主鍵(e_no),如下圖 : Employees 專員 專員 副理 經理 position 002 002 001 NULL boss 30000 李四 004 40000 張三 003 50000 江小魚 002 800000 陳會安 001 salary name e_no 3-4-2 定義域限制條件 定義域限制條件(Domain Constraints)是指在關聯表的屬性值一定是定義域的單元值(Atomic)。例如:屬性age的定義域是int,屬性值可以為5,但不可以是4.5。對比程式語言,就是一種「強調型別」(Strongly Typed)程式語言。相對於強調型別程式語言是「鬆散型別」(loosely Typed)程式語言,其變數不需要事先宣告就可以使用。 3-4-3 實體完整性 – 說明 實體完整性是關聯表內部的完整性條件,主要是用來規範關聯表主鍵的使用規則。 實體完整性(Entity Integrity)是指在基底關聯表主鍵的任何部分都不可是空值,其規則如下所示: 主鍵如果是多個屬性的集合,任何一個屬性都不可是空值,例如:(ename, cname)是主鍵,ename屬性不可為空值;cname屬性也不可是空值。 在關聯表只有主鍵不可是空值,其他替代鍵並不適用此規則。 實體完整性是針對基底關聯表,從其導出的關聯表並不用遵守。 3-4-3 實體完整性 – 主鍵的使用規則 「規則」(Rule) 是以敘述方式說明發生的原因和將會有什麼影響,這是由資料庫系統所定義完整性限制條件的執行方式。 關聯式資料庫

文档评论(0)

zhuwo + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档