設定方法:在「CREATE TABLE」語句中,透過「PRIMARY KEY」關鍵字來指定主鍵,語法格式「欄位名稱資料類型PRIMARY KEY [預設值]」或「[CONSTRAINT 約束名稱] PRIMARY KEY 欄位名稱」。
主鍵(PRIMARY KEY)的完整稱呼是“主鍵約束”,是 MySQL 中使用最頻繁的限制。一般情況下,為了方便 DBMS 更快的查找到表中的記錄,都會在表中設定一個主鍵。
(推薦教學:mysql影片教學)
1)設定單一欄位主鍵
在 CREATE TABLE 語句中,透過PRIMARY KEY 關鍵字來指定主鍵。
<字段名> <数据类型> PRIMARY KEY [默认值]範例1在test_db 資料庫中建立tb_emp3 資料表,其主鍵為id,SQL 語句和運行結果如下。
mysql> CREATE TABLE tb_emp3 -> ( -> id INT(11) PRIMARY KEY, -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp3; +--------+-------------+------+-----+---------+-------+ | 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 [字段名]範例2在test_db 資料庫中建立tb_emp4 資料表,其主鍵為id ,SQL 語句和運行結果如下。
mysql> CREATE TABLE tb_emp4 -> ( -> 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_emp4; +--------+-------------+------+-----+---------+-------+ | 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)在建立表格時設定聯合主鍵
所謂的聯合主鍵,就是這個主鍵是由一張表中多個欄位組成的。 例如,設定學生選課資料表時,使用學生編號做主鍵還是用課程編號做主鍵呢?如果用學生編號做主鍵,那麼一個學生就只能選擇一門課程。如果用課程編號做主鍵,那麼一門課程只能有一個學生來選。顯然,這兩種情況都是不符合實際情況的。 實際上設計學生選課表,要限定的是一位學生只能選擇同一課程一次。因此,學生編號和課程編號可以放在一起共同作為主鍵,也就是聯合主鍵了。 主鍵由多個欄位聯合組成,語法格式如下:PRIMARY KEY [字段1,字段2,…,字段n]注意:當主鍵是由多個欄位組成時,不能直接在欄位名稱後面宣告主鍵約束。 例 3建立資料表 tb_emp5,假設表中沒有主鍵 id,為了唯一確定一個員工,可以把 name、deptId 聯合起來作為主鍵,SQL 語句和運行結果如下。
mysql> CREATE TABLE tb_emp5 -> ( -> name VARCHAR(25), -> deptId INT(11), -> salary FLOAT, -> PRIMARY KEY(id,deptId) -> ); Query OK, 0 rows affected (0.37 sec) mysql> DESC tb_emp5; +--------+-------------+------+-----+---------+-------+ | 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)相關推薦:
以上是mysql建表時怎麼設定主鍵?的詳細內容。更多資訊請關注PHP中文網其他相關文章!