當前位置:首頁 » 數據倉庫 » 資料庫連接為什麼要使用主鍵
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

資料庫連接為什麼要使用主鍵

發布時間: 2022-04-14 08:34:00

資料庫表中的主鍵有什麼作用

資料庫主鍵

主鍵:表中經常有一個列或多列的組合,其值能唯一地標識表中的每一行。這樣的一列或多列稱為表的主鍵,通過它可強製表的實體完整性。當創建或更改表時可通過定義 PRIMARY KEY 約束來創建主鍵。一個表只能有一個 PRIMARY KEY 約束,而且 PRIMARY KEY 約束中的列不能接受空值。由於 PRIMARY KEY 約束確保唯一數據,所以經常用來定義標識列。

作用:

1)保證實體的完整性;

2)加快資料庫的操作速度

3) 在表中添加新記錄時,ACCESS會自動檢查新記錄的主鍵值,不允許該值與其他記錄的主鍵值重復。

4) ACCESS自動按主鍵值的順序顯示表中的記錄。如果沒有定義主鍵,則按輸入記錄的順序顯示表中的記錄。

在有些資料庫中,雖然主鍵不是必需的,但最好為每個表都設置一個主鍵,不管是單主鍵還是復合主鍵。它存在代表著表結構的完整性,表的記錄必須得有唯一區分的欄位,主鍵主要是用於其他表的外鍵關聯,以及本記錄的修改與刪除。

主鍵的無意義性

在開發過程中,讀者可能會看到將一些表使用有意義的欄位表示主鍵,例如「用戶登錄信息表」將「登錄名」(英文名)作為主鍵,「訂單表」中將「訂單編號」作為主鍵,如此設計主鍵一般都是沒什麼問題,因為將這些主鍵基本不具有「意義更改」的可能性。但是,也有一些例外的情況,例如「訂單表」需要支持需求「訂單可以作廢,並重新生成訂單,而且訂單號要保持原訂單號一致」,那將「訂單編號」作為主鍵就滿足不了要求了。因此讀者在使用具有實際意義的欄位作為主鍵時,需要考慮是否存在這種可能性。

主鍵的選擇

①編號作主鍵

此方法就是採用實際業務中的唯一欄位的「編號」作為主鍵設計,這在小型的項目中是推薦這樣做的,因為這可以使項目比較簡單化,但在使用中卻可能帶來一些麻煩,比如要進行「編號修改」時,可能要涉及到很多相關聯的其他表,就像黎叔說的「後果很嚴重」;還有就是上面提到的「業務要求允許編號重復時」,我們再那麼先知,都無法知道業務將會修改成什麼?

②自動編號主鍵

這種方法也是很多朋友在使用的,就是新建一個ID欄位,自動增長,非常方便也滿足主鍵的原則,優點是:資料庫自動編號,速度快,而且是增量增長,聚集型主鍵按順序存放,對於檢索非常有利;數字型的,佔用空間小,易排序,在程序中傳遞也方便;如果通過非系統增加記錄(比如手動錄入,或是用其他工具直接在表裡插入新記錄,或老系統數據導入)時,非常方便,不用擔心主鍵重復問題。

缺點:其實缺點也就是來自其優點,就是因為自動增長,在手動要插入指定ID的記錄時會顯得麻煩,尤其是當系統與其他系統集成時,需要數據導入時,很難保證原系統的ID不發生主鍵沖突(前提是老系統也是數字型的);如果其他系統主鍵不是數字型那就麻煩更大了,會導致修改主鍵數據類型了,這也會導致其他相關表的修改,後果同樣很嚴重;就算其他系統也是數字型的,在導入時,為了區分新老數據,可能想在老數據主鍵前統一加一個「o」(old)來表示這是老數據,那麼自動增長的數字型又面臨一個挑戰。

⑵ 資料庫題目:為什麼要設置主鍵不設置會有什麼後果

主鍵用於表示數據(記錄)的唯一性, 不設置主鍵會導致數據表中可能存在完全相同的數據, 因此在對數據進行操作時, 資料庫無法區分這些相同的數據, 因而會產生不想要的操作結果
另外, 主鍵還有助於提高數據的檢索速度

⑶ 資料庫中設置主鍵是為了什麼,用通俗易懂的語言解釋

為了保證實體的完整性,
主鍵
必須不空不重,比如學生信息表,
學號
是主鍵,那麼就要求每個學生必須有學號,並且所有學生的學號不得重復.

⑷ 資料庫中為何要設置主鍵呢有什麼作用

主鍵:
概念
主關鍵字(主鍵,primary
key)是被挑選出來,作表的行的惟一標識的候選關鍵字。一個表只有一個主關鍵字。主關鍵字又可以稱為主鍵。
主鍵可以由一個欄位,也可以由多個欄位組成,分別成為單欄位主鍵或多欄位主鍵。
作用
1)保證實體的完整性;
2)加快資料庫的操作速度
3)
在表中添加新記錄時,ACCESS會自動檢查新記錄的主鍵值,不允許該值與其他記錄的主鍵值重復。
4)
ACCESS自動按主鍵值的順序顯示表中的記錄。如果沒有定義主鍵,則按輸入記錄的順序顯示表中的記錄。
特點
1)
一個表中只能有一個主鍵。如果在其他欄位上建立主鍵,則原來的主鍵就會取消。在ACCESS中,雖然主鍵不是必需的,但最好為每個表都設置一個主鍵。
2)主鍵的值不可重復,也不可為空(NULL)。

⑸ 我想知道資料庫中設置主鍵的作用

1、保證每個實體的完整性;

2、加快資料庫的操作速度,更好地給用戶帶來體驗;

3、在表中添加新記錄時,DBMS會自動檢查新記錄的主鍵值,不允許該值與其他記錄的主鍵值重復;

4、DBMS自動按主鍵值的順序顯示表中的記錄。如果沒有定義主鍵,則按輸入記錄的順序顯示表中的記錄。

當創建或更改表時可通過定義 PRIMARY KEY 約束來創建主鍵。一個表只能有一個 PRIMARY KEY 約束,而且 PRIMARY KEY 約束中的列不能接受空值。

(5)資料庫連接為什麼要使用主鍵擴展閱讀

主鍵的使用規則介紹:

1、任意兩行都不具有相同的主鍵值;

2、每行都必須具有一個主鍵值(主鍵列不允許NULL值);

3、可以使用多個列作為主鍵,但是所有列值得組合必須是唯一的(但單個列的值可以不唯一);

4、不更新主鍵列中的值;

5、不重用主鍵列的值;

6、不在主鍵列中使用可能會更改的值(例如,供應商的名字,如果供應商更改了名字,你就得改這個主鍵)。

⑹ 資料庫中建「索引」和「主鍵」有什麼作用

主鍵的作用是防止數據重復,是一種約束;索引的目的是加快檢索速度,只有恰當的建立索引,系統才能快速運行

⑺ 資料庫主鍵具體指哪項,有什麼作用

主鍵:
關系資料庫依賴於主鍵---它是資料庫物理模式的基石。主鍵在物理層面上只有兩個用途:
1.
惟一地標識一行。
2.
作為一個可以被外鍵有效引用的對象。
基於以上這兩個用途,下面給出了我在設計物理層面的主鍵時所遵循的一些原則:
1.
主鍵應當是對用戶沒有意義的。如果用戶看到了一個表示多對多關系的連接表中的數據,並抱怨它沒有什麼用處,那就證明它的主鍵設計地很好。
2.
主鍵應該是單列的,以便提高連接和篩選操作的效率。
註:使用復合鍵的人通常有兩個理由為自己開脫,而這兩個理由都是錯誤的。其一是主鍵應當具有實際意義,然而,讓主鍵具有意義只不過是給人為地破壞資料庫提供了方便。其二是利用這種方法可以在描述多對多關系的連接表中使用兩個外部鍵來作為主鍵,我也反對這種做法,理由是:復合主鍵常常導致不良的外鍵,即當連接表成為另一個從表的主表,而依據上面的第二種方法成為這個表主鍵的一部分,然,這個表又有可能再成為其它從表的主表,其主鍵又有可能成了其它從表主鍵的一部分,如此傳遞下去,越靠後的從表,其主鍵將會包含越多的列了。
3.
永遠也不要更新主鍵。實際上,因為主鍵除了惟一地標識一行之外,再沒有其他的用途了,所以也就沒有理由去對它更新。如果主鍵需要更新,則說明主鍵應對用戶無意義的原則被違反了。
註:這項原則對於那些經常需要在數據轉換或多資料庫合並時進行數據整理的數據並不適用。
4.
主鍵不應包含動態變化的數據,如時間戳、創建時間列、修改時間列等。
5.
主鍵應當有計算機自動生成。如果由人來對主鍵的創建進行干預,就會使它帶有除了惟一標識一行以外的意義。一旦越過這個界限,就可能產生認為修改主鍵的動機,這樣,這種系統用來鏈接記錄行、管理記錄行的關鍵手段就會落入不了解資料庫設計的人的手中。
外鍵是資料庫一級的一個完整性約束,就是資料庫基礎理論書中所說的「參照完整性」的資料庫實現方式。
外鍵屬性當然是可以去掉的,如果你不想再用這種約束,對編程當然不會有什麼影響,但相應的錄入數據的時候就不對錄入的數據進行「參照完整性」檢查了。
例如有兩個表
A(a,b)
:a為主鍵,b為外鍵(來自於B.b)
B(b,c,d)
:b為主鍵
如果我把欄位b的外鍵屬性去掉,對編程沒什麼影響。
如上面,A中的b要麼為空,要麼是在B的b中存在的值,有外鍵的時候,資料庫會自動幫你檢查A的b是否在B的b中存在。

⑻ 資料庫中 建立表時為什麼要設置主鍵

主鍵的值用於惟一地標識表中的某一條記錄,一個表只有一個主鍵。主鍵可以由一個欄位,也可以由多個欄位組成。
主鍵上會自動創建索引

⑼ 資料庫:什麼是主鍵設置主鍵的意義是什麼

主鍵就是數據表中某一行數據中的某一欄位的唯一值,假設做個客戶信息提交資料庫,那個電話就是個唯一值,設電話那個欄位為主鍵的話,就不會有客戶用同樣的手機號碼提交進來,且重復提交的用戶會有錯誤提示,提示不可重復提交。