首頁  >  文章  >  資料庫  >  mysql如何增加唯一索引

mysql如何增加唯一索引

青灯夜游
青灯夜游原創
2022-06-20 18:50:0221085瀏覽

三種增加方法: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索引,請使用以下<span style="background-color: rgb(255, 255, 255); color: rgb(68, 68, 68); font-family: " helvetica neue yahei arial sans-serif>CREATE INDEX</span>語句:

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索引範例

mysql如何增加唯一索引

mysql如何增加唯一索引

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

要強制執行此規則,請在CREATE TABLE語句中建立唯一約束,如下所示:mysql如何增加唯一索引

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)
);

如果使用SHOW INDEXES語句,您將看到MySQL UNIQUE為email列建立了索引。 mysql如何增加唯一索引

SHOW INDEXES FROM contacts;

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

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

現在,如果您嘗試插入其電子郵件所在的行john.doe@mysqltutorial.org,您將收到錯誤訊息。 ###
INSERT INTO contacts(first_name,last_name,phone,email)
VALUES(&#39;Johny&#39;,&#39;Doe&#39;,&#39;(408)-999-4321&#39;,&#39;john.doe@mysqltutorial.org&#39;);
ERROR 1062 (23000): Duplicate entry &#39;john.doe@mysqltutorial.org&#39; for key &#39;unique_email&#39;
############假設你想要的組合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(&#39;john&#39;,&#39;doe&#39;,&#39;(408)-999-9765&#39;,&#39;john.d@mysqltutorial.org&#39;);
ERROR 1062 (23000): Duplicate entry &#39;john-doe-(408)-999-9765&#39; for key &#39;idx_name_phone&#39;
###【相關推薦:###mysql影片教學###】###

以上是mysql如何增加唯一索引的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn