回覆列表
  • 1 # 貓Ning

    一、什麼是主鍵、外來鍵:

    關係型資料庫中的一條記錄中有若干個屬性,若其中某一個屬性組(注意是組)能唯一標識一條記錄,該屬性組就可以成為一個主鍵。

    主鍵是能確定一條記錄的唯一標識,比如,一條記錄包括身份證號,姓名,年齡。身份證號是唯一能確定你這個人的,其他都可能有重複,所以,身份證號是主鍵。

    外來鍵用於與另一張表的關聯。是能確定另一張表記錄的欄位,用於保持資料的一致性。比如,A表中的一個欄位,是B表的主鍵,那他就可以是A表的外來鍵。

    二、 主鍵、外來鍵 和索引的區別

    定義: 唯一標識一條記錄,不能有重複的,不允許為空 表的外來鍵是另一表的主鍵, 外來鍵可以有重複的, 可以是空值

    該欄位沒有重複值,但可以有一個空值作用: 用來保證資料完整性 用來和其他表建立聯絡用的 是提高查詢排序的速度個數: 主鍵只能有一個

    一個表可以有多個外來鍵 一個表可以有多個惟一索引

    聚集索引和非聚集索引的區別?聚集索引一定是唯一索引。但唯一索引不一定是聚集索引。

    聚集索引,在索引頁裡直接存放資料,而非聚集索引在索引頁裡存放的是索引,這些索引指向專門的資料頁的資料。

    三、資料庫中主鍵和外來鍵的設計原則

    關係資料庫依賴於主鍵---它是資料庫物理模式的基石。主鍵在物理層面上只有兩個用途:

    1、惟一地標識一行。

    2、作為一個可以被外來鍵有效引用的物件。

    3、主鍵應當是對使用者沒有意義的。如果使用者看到了一個表示多對多關係的連線表中的資料,並抱怨它沒有什麼用處,那就證明它的主鍵設計地很好。

    4、主鍵應該是單列的,以便提高連線和篩選操作的效率。

    5、永遠也不要更新主鍵。實際上,因為主鍵除了惟一地標識一行之外,再沒有其他的用途了,所以也就沒有理由去對它更新。如果主鍵需要更新,則說明主鍵應對使用者無意義的原則被違反了。

    6、主鍵不應包含動態變化的資料,如時間戳、建立時間列、修改時間列等。

    7、主鍵應當有計算機自動生成。如果由人來對主鍵的建立進行干預,就會使它帶有除了惟一標識一行以外的意義。一旦越過這個界限,就可能產生認為修改主鍵的動機,這樣,這種系統用來連結記錄行、管理記錄行的關鍵手段就會落入不瞭解資料庫設計的人的手中。

  • 中秋節和大豐收的關聯?
  • 求一首表白的詩?