1. 資料庫中資料庫中 碼、候選碼、外部碼之間的關系是什麼
主碼是從候選碼中挑出來的一個作為主碼,主碼和外部碼提供了一種表示不同關系之間相互關聯的手段。
資料庫中碼又稱資料庫主碼,是資料庫中唯一能標識一個記錄值的內部記錄標志符。
若關系中的一個屬性或屬性組的值能夠唯一地標識一個元組,且他的真子集不能唯一的標識一個元組,則稱這個屬性或屬性組做候選碼。
關系模式R中屬性或屬性組X並非R的候選碼,但X是另一個關系模式的候選碼,且X與R的主碼對應,則稱X是R的外部碼,也稱外碼。
(1)資料庫中的碼是候選碼還是主碼擴展閱讀:
在兩個表的關系中,主碼用來在一個表中引用來自於另一個表中的特定記錄。主碼表定義的一部分。一個表的主鍵可以由多個主碼共同組成,並且主碼的列不能包含空值。主碼是可選的,並且可在 CREATE TABLE 或 ALTER TABLE 語句中定義。
一個表中只能有一個主鍵。如果在其他欄位上建立主鍵,則原來的主鍵就會取消。主鍵的值不可重復,也不可為空(NULL)。
2. 主碼、候選碼、外部碼之間的聯系與區別
主碼包含候選碼和碼,候選碼包含碼。
1、含義不同:若關系中的某一屬性組的值能唯一地標識一個元組,則稱該屬性組為候選碼;若一個關系有多個候選碼,其中任何一個都可以做主碼,主碼的諸屬性就稱為主屬性;一個表中如果有一個欄位,存儲另外一個表的主鍵,這個欄位就是外鍵,又稱外碼。
2、實際操作不同:碼是可以確定一個元組的所有信息的屬性名或屬性名組。
例如在{a,b,c,d}中,假設知道a的值就能確定a,b,c,d的值,假設知道c,d的值就可以確定a,b,c,d的值,那麼{a}就是碼,{c,d}就是碼。
並且{a,b},{a,c},{a,b,c},{a,b,c,d}等也都是碼,因為它們也可以確定一個元組的所有值,即使很多餘。
候選碼的真子集中不存在碼,候選碼可以有多個。
就上面的例子而言,{a}是候選碼,{c,d}是候選碼,因為它們的真子集中不存在碼。
而諸如{a,b}並不是候選碼,因為它的真子集中含有{a},且{a}是碼。
主碼就是主鍵的意思,主碼是任意一個候選碼,還是上面的例子,主碼是候選碼{a},{c,d}中的其中一個,既可以是{a},也可以是{c,d}。
3、定義概念不同:碼是數據系統中的基本概念。所謂碼就是能唯一標識實體的屬性,他是整個實體集的性質,而不是單個實體的性質。它包括超碼,候選碼,主碼。
超碼是一個或多個屬性的集合,這些屬性可以讓我們在一個實體集中唯一地標識一個實體。如果K是一個超碼,那麼K的任意超集也是超碼,也就是說如果K是超碼,那麼所有包含K的集合也是超碼。
候選碼是從超碼中選出的,自然地候選碼也是一個或多個屬性的集合。因為超碼的范圍太廣,很多是我們並不感興趣即無用處的。
所以候選碼是最小超碼,它們的任意真子集都不能成為超碼。例如,如果K是超碼,那麼所有包含K的集合都不能是候選碼;如果K,J都不是超碼,那麼K和J組成的集合(K,J)有可能是候選碼。
按照上面碼的定義看看外碼的定義如下:
設F是基本關系R的一個或者一組屬性,但不是關系R的碼。K(s)是基本關系S的主碼。如果F與K(s)相對對應,則稱F是R的外碼。
綜上:F是非主屬性組,必定可以取空值,但是課本例子包括課後題都說F可以是主屬性,當為主屬性時,為了保持實體完整性,不可以取空值。
(2)資料庫中的碼是候選碼還是主碼擴展閱讀:
碼=超鍵:能夠唯一標識一條記錄的屬性或屬性集。
標識性:一個數據表的所有記錄都具有不同的超鍵;非空性:不能為空;有些時候也把碼稱作「鍵」。
候選鍵=候選碼:能夠唯一標識一條記錄的最小屬性集;標識性:一個數據表的所有記錄都具有不同的候選鍵;
最小性:任一候選鍵的任何真子集都不能唯一標識一個記錄(比如在成績表中(學號,課程號)是一個候選鍵,單獨的學號,課程號都不能決定一條記錄)。
非空性:不能為空;候選鍵是沒有多餘屬性的超鍵;舉例:學生ID是候選碼,那麼含有候選碼的都是碼,少部分地方也有叫超級碼的,但是見得不多。
主鍵=主碼:某個能夠唯一標識一條記錄的最小屬性集(是從候選碼里人為挑選的一條)。
唯一性:一個數據表只能有一個主鍵;標識性:一個數據表的所有記錄都具有不同的主鍵取值;
非空性:不能為空;人為的選取某個候選碼為主碼。
3. 資料庫中主鍵、主碼、主屬性、關鍵字、候選關鍵字、碼的區別
1、關系:
主碼=主鍵=主關鍵字;
關鍵字=候選碼;
候選關鍵字=候選碼中除去主碼的其他候選碼;
2、理解:
主碼(主鍵、主關鍵字):若一個關系有多個候選碼,選擇其中一個為主碼。
候選碼(關鍵字):某一屬性組的值能唯一標識一個元組而其子集不能(去掉任意一個屬性都不能標識該元組),則稱該屬性組為候選碼(補充元組:表中的一行即為一個元組)。
主屬性:候選碼包含的屬性(一個或多個屬性)。
碼:唯一標識實體的屬性或屬性組合稱為碼。
(3)資料庫中的碼是候選碼還是主碼擴展閱讀:
常見的資料庫欄位類型如下:
1、Char固定長度字元串最大長度2000bytes。
2、VARCHAR2可變長度字元串最大長度4000bytes,索引最大長度749。
3、NCHAR基於字元集NCHAR固定長度字元串的最大長度2000bytes。
4、Nvarchar2基於字元集的可變長度字元串最大長度4000bytes。
5、DATE日期(日-月-年)DD-MM-YY(HH-MI-SS)經過嚴格測試,無千蟲問題。
6、LONG超長字元串的最大長度為2G(231-1),足以存儲大多數標題。
7、RAW原始定長二進制數據最大長度2000位元組可存儲多媒體圖像聲音等。
8、LONG RAW長原始可變長度二進制數據最大長度2G,同上。
9、BLOB二進制數據最大長度4G CLOB字元數據最大長度4G。
10、NCLOB基於字元集4G的nclb最大字元數據長度。
11、BFILE資料庫外存儲的BFILE二進制數據的最大長度為4G。
4. 資料庫中的碼是什麼含義
資料庫碼是資料庫中唯一能標識一個記錄值的內部記錄標志符。
相關介紹:
資料庫碼通常包括「域號」、「頁號」、「行號」等部分。當記錄存入資料庫時,資料庫就自動賦給它一個關鍵碼。使用關鍵碼可以加速存取記錄的速度,於中文數據,資料庫字元編碼的設置應當保證數據的完整性。
(4)資料庫中的碼是候選碼還是主碼擴展閱讀
在計算機技術發展的早期,如ASCII(1963年)和EBCDIC(1964年)這樣的字元集逐漸成為標准。但這些字元集的局限很快就變得明顯,於是人們開發了許多方法來擴展它們。
對於支持包括東亞CJK字元家族在內的寫作系統的要求能支持更大量的字元,並且需要一種系統而不是臨時的方法實現這些字元的編碼。
為了擴充ASCII編碼,以用於顯示本國的語言,不同的國家和地區制定了不同的標准,由此產生了 GB2312、BIG5、JIS等各自的編碼標准。