這篇文章給大家分享的是有關(guān)MySQL添加主鍵的方法的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)是一家專注于網(wǎng)站設(shè)計(jì)、成都網(wǎng)站設(shè)計(jì)與策劃設(shè)計(jì),無極網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)10年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:無極等地區(qū)。無極做網(wǎng)站價格咨詢:13518219792
“主鍵(PRIMARY KEY)”的完整稱呼是“主鍵約束”。MySQL 主鍵約束是一個列或者列的組合,其值能唯一地標(biāo)識表中的每一行。這樣的一列或多列稱為表的主鍵,通過它可以強(qiáng)制表的實(shí)體完整性。那么在MySQL中如何添加主鍵約束?下面本篇文章就給大家介紹一下。
主鍵約束即在表中定義一個主鍵來唯一確定表中每一行數(shù)據(jù)的標(biāo)識符。主鍵可以是表中的某一列或者多列的組合,其中由多列組合的主鍵稱為復(fù)合主鍵。主鍵應(yīng)該遵守下面的規(guī)則:
● 每個表只能定義一個主鍵。
● 主鍵值必須唯一標(biāo)識表中的每一行,且不能為 NULL,即表中不可能存在兩行數(shù)據(jù)有相同的主鍵值。這是唯一性原則。
● 一個列名只能在復(fù)合主鍵列表中出現(xiàn)一次。
● 復(fù)合主鍵不能包含不必要的多余列。當(dāng)把復(fù)合主鍵的某一列刪除后,如果剩下的列構(gòu)成的主鍵仍然滿足唯一性原則,那么這個復(fù)合主鍵是不正確的。這是最小化原則。
1、在創(chuàng)建表時添加主鍵約束
在 CREATE TABLE 語句中,主鍵是通過 PRIMARY KEY 關(guān)鍵字來指定的。
在定義列的同時指定主鍵,語法規(guī)則如下:
<字段名> <數(shù)據(jù)類型> PRIMARY KEY [默認(rèn)值]
例:在 test_db 數(shù)據(jù)庫中創(chuàng)建 tb_emp 1 數(shù)據(jù)表,其主鍵為 id
mysql> CREATE TABLE tb_emp1 -> ( -> id INT(11) PRIMARY KEY, -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp1; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(25) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.14 sec)
在定義完所有列之后,指定主鍵的語法格式為:
[CONSTRAINT <約束名>] PRIMARY KEY [字段名]
示例:在 test_db 數(shù)據(jù)庫中創(chuàng)建 tb_emp 2 數(shù)據(jù)表,其主鍵為 id
mysql> CREATE TABLE tb_emp2 -> ( -> id INT(11), -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT, -> PRIMARY KEY(id) -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp2; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(25) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.14 sec)
2、在創(chuàng)建表后添加主鍵約束
創(chuàng)建表后,可以在修改數(shù)據(jù)表時添加主鍵約束,語法規(guī)則為:
ALTER TABLE <數(shù)據(jù)表名> ADD PRIMARY KEY(<列名>);
示例:修改數(shù)據(jù)表 tb_emp3,將字段 id 設(shè)置為主鍵
mysql> ALTER TABLE tb_emp3 -> ADD PRIMARY KEY(id); Query OK, 0 rows affected (0.94 sec) Records: 0 Duplicates: 0 Warnings: 0 mysql> DESC tb_emp3; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | id | int(11) | NO | PRI | NULL | | | name | varchar(30) | YES | | NULL | | | deptId | int(11) | YES | | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 4 rows in set (0.12 sec)
3、設(shè)置復(fù)合主鍵
也可以在創(chuàng)建表時添加復(fù)合主鍵,此時主鍵由多個字段聯(lián)合組成,語法規(guī)則如下:
PRIMARY KEY [字段1,字段2,…,字段n]
示例:創(chuàng)建數(shù)據(jù)表 tb_emp4,假設(shè)表中沒有主鍵 id,為了唯一確定一個員工,可以把 name、deptId 聯(lián)合起來作為主鍵
mysql> CREATE TABLE tb_emp4 -> ( -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT, -> PRIMARY KEY(id,deptId) -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp4; +--------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +--------+-------------+------+-----+---------+-------+ | name | varchar(25) | NO | PRI | NULL | | | deptId | int(11) | NO | PRI | NULL | | | salary | float | YES | | NULL | | +--------+-------------+------+-----+---------+-------+ 3 rows in set (0.14 sec)
感謝各位的閱讀!關(guān)于mysql添加主鍵的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!