mysql如何增加唯一索引

三種增加方法:1、使用“CREATE INDEX”語句增加,語法“CREATE UNIQUE INDEX 索引名 ON 表名(列名列表);”;2、建表時增加,語法“CREATE TABLE 表名(… UNIQUE KEY(列名列表) );”;3、修改表時增加,語法“ALTER TABLE 表名 ADD CONSTRAINT 索引名 UNIQUE KEY(列名列表);”。

mysql如何增加唯一索引

本教程操作環境:windows7系統、mysql8版本、Dell G3電腦。

mysql唯一索引(UNIQUE)

要強制執行一列或多列的唯一性值,通常使用PRIMARY KEY約束。但是,每個表只能有一個主鍵。因此,如果要包含多個列或一組具有唯一值的列,則不能使用主鍵約束。

幸運的是,MySQL提供了另一種指標叫做UNIQUE索引,使您可以強制執行值的唯一的一列或多列。與PRIMARY KEY?索引不同,UNIQUE每個表可以有多個索引。

要創建UNIQUE索引,請使用以下CREATE INDEX語句:

CREATE?UNIQUE?INDEX?索引名 ON?表名(列名1,列名2,...);

在一列或多列中強制執行值唯一性的另一種方法是使用UNIQUE約束。

創建UNIQUE約束時,MySQL會UNIQUE在幕后創建索引。

以下語句說明了在創建表時如何創建唯一約束。

CREATE?TABLE?表名( ... ???UNIQUE?KEY(列名1,列名2,...)? );

也可以使用ALTER TABLE語句給現有表添加唯一索引(UNIQUE)

ALTER?TABLE?表名 ADD?CONSTRAINT?索引名?UNIQUE?KEY(列名1,列名2,...);

MySQL UNIQUE索引示例

假設您要管理應用程序中的聯系人。您還希望contacts表中每個聯系人的電子郵件必須是唯一的。

要強制執行此規則,請在CREATE TABLE語句中創建唯一約束,如下所示:

CREATE?TABLE?IF?NOT?EXISTS?contacts?( ????id?INT?AUTO_INCREMENT?PRIMARY?KEY, ????first_name?VARCHAR(50)?NOT?NULL, ????last_name?VARCHAR(50)?NOT?NULL, ????phone?VARCHAR(15)?NOT?NULL, ????email?VARCHAR(100)?NOT?NULL, ????UNIQUE?KEY?unique_email?(email) );

mysql如何增加唯一索引

如果使用SHOW INDEXES語句,您將看到MySQL?UNIQUE為email列創建了索引。

SHOW?INDEXES?FROM?contacts;

mysql如何增加唯一索引

讓我們在contacts表格中插入一行。

INSERT?INTO?contacts(first_name,last_name,phone,email) VALUES('John','Doe','(408)-999-9765','john.doe@mysqltutorial.org');

mysql如何增加唯一索引

現在,如果您嘗試插入其電子郵件所在的行john.doe@mysqltutorial.org,您將收到錯誤消息。

INSERT?INTO?contacts(first_name,last_name,phone,email) VALUES('Johny','Doe','(408)-999-4321','john.doe@mysqltutorial.org');
ERROR?1062?(23000):?Duplicate?entry?'john.doe@mysqltutorial.org'?for?key?'unique_email'

mysql如何增加唯一索引

假設你想要的組合first_name,last_name和? ?phone也接觸中是唯一的。在這種情況下,您可以使用CREATE INDEX語句UNIQUE為這些列創建索引,如下所示:

CREATE?UNIQUE?INDEX?idx_name_phone ON?contacts(first_name,last_name,phone);

添加下面一行到contacts因為組合表會導致錯誤first_name,last_name以及phone已經存在。

INSERT?INTO?contacts(first_name,last_name,phone,email) VALUES('john','doe','(408)-999-9765','john.d@mysqltutorial.org');
ERROR?1062?(23000):?Duplicate?entry?'john-doe-(408)-999-9765'?for?key?'idx_name_phone'

【相關推薦:mysql視頻教程

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊9 分享