|
|
data:image/s3,"s3://crabby-images/a08c1/a08c1625782e92eeacea486ccf71f98523a8c0e9" alt="" |
|
當我們設計資料庫中的關聯式綱要時,如何表現出屬性間的關係是一件非常重要的工作,這些屬性間的關係就是所謂的功能相依性(Functional
Dependencies)。
|
功能相依性(Functional Dependency,FD) |
定義:假如 R 代表一個關聯表,X 與 Y 為 R
的屬性的子集合。若且唯若(If and only if) R 的 X 值可以唯一決定 Y 的值時,稱為“Y
功能相依於 X”(Y is functionally Dependent on X) 或稱為“X
功能決定 Y”(X funtionally determines Y),以 X→Y 表示。換另一種說法:若且唯若對於 R 中的每一個 X
值,都有唯一的 Y 值與其對應。
|
data:image/s3,"s3://crabby-images/ecf46/ecf465312848272a24cde951aa6f674e801a1102" alt="" |
學生選課資料中包括學生學號(Sno)、課程代號(Cno)、學分數(Credit)
與成績(Score)。其功能相依性 FD 如下:
(Sno , Cno) → Score,Cno →Cname ,Cno → Credit
其中(Sno , Cno) 為主鍵,它可決定唯一的 Credit 值與 Score 值。
|
|
Sno
|
Cno
|
Cname
|
Credit
|
Score
|
S1879032
|
Math1416
|
工程數學(一)
|
3
|
60
|
S1879044
|
Math1416
|
工程數學(一)
|
3
|
80
|
S1879044
|
Cs1318
|
計算機概論
|
4
|
80
|
…
|
…
|
…
|
…
|
…
|
S1879032
|
Cs1446
|
資料庫
|
2
|
65
|
圖 1 學生選課表格 SC
|
|
data:image/s3,"s3://crabby-images/256bd/256bd329dc70f94e29f033c78727b79f926cd171" alt="" |
|
若 X→Y 時,X 稱為功能相依決定者(determinant),Y
則稱為功能相依者(Dependent)。
值得注意的是,如果 X 是關聯表 R 中的候選鍵 (或是主鍵),則 R 中所有的屬性必須功能相依於 X。如例 1
中,所有的屬性都功能相依於主鍵(Sno , Cno)。
|
data:image/s3,"s3://crabby-images/e38f1/e38f18ba519ee4fed65221d3d559032b510db1fd" alt=""
(Armstrong's Axioms) |
|
功能相依性必須依循阿姆斯壯定理,這些定理可以用來對功能相依性做進一步的處理,其主要目的在於推導隱含(Implicit) 的功能相依性集合。
假設 A、B、C、D 為關聯表 R 的屬性中的三個任意子集合(Subset),而且 AB 表示 A 聯集 B。則阿姆斯壯定理如下:
|
data:image/s3,"s3://crabby-images/ae439/ae4393c3e1b99edacc250f7cf8a7de3b4961d673" alt="" |
反身性(Reflexivity):若 B 是 A
的子集合,則 A→B。 |
data:image/s3,"s3://crabby-images/556d5/556d5f1f6d1f66854414061e472b1fa855020100" alt="" |
擴增性(Augmentation):若 A→B,則
AC→BC。 |
data:image/s3,"s3://crabby-images/e4b3c/e4b3c3927d640771a9f484c3bcbf047cd770b58d" alt="" |
遞移性(Transitivity):若 A→B,且
B→C 則 A→C。 |
|
以上三個定理可利用功能相依性的基本定義來證明,稱為基本定理。
|
data:image/s3,"s3://crabby-images/0748c/0748cc66fc18fe69b74ae2c0b1f2760b98384b25" alt="" |
分解性(Decomposition):若 A→BC
則 A→B 且 A→C。 |
data:image/s3,"s3://crabby-images/424da/424da154ac161bc6e35765658c2a903aa549f888" alt="" |
聯合性(Union):若 A→B 且 A→C 則
A→BC。 |
data:image/s3,"s3://crabby-images/86f84/86f84d7c16b07b31ad7cc811b81ddd830719828b" alt="" |
虛擬遞移性(Pseudotransitive):若
A→B 且 BC→D 則 AC→D。 |
|
以上的定理,可利用阿姆斯壯定理的基本定理證明,稱為衍生定理。
阿姆斯壯定理可利用已知的功能相依性,推導出其他隱含(Implicit) 的功能相依性,這些定理在於找出關聯表中的候選鍵或主鍵是相當有用的工具。
|
data:image/s3,"s3://crabby-images/34be7/34be7cb1538b1dfce40af391cf32701bc50ff16c" alt="" |
|
功能相依性(FD)
集合可以用圖的方式表示,稱為功能相依圖(Functional Dependency Diagram,
FD Diagram)。
|
data:image/s3,"s3://crabby-images/3e556/3e5561a05c294f6d6ea09d71d363fd9191cf6be4" alt="" |
學生選課資料的功能相依性(FD)
為:
(Sno,
Cno) → Score
Cno
→ Cname
Cno
→ Credit
|
|
其功能相依圖如下: |
|
data:image/s3,"s3://crabby-images/2620c/2620cc59df0ce44da98439a925e8f792b7e22af7" alt=""
圖 1 學生選課資料的功能相依圖
|
|
|