摘要:在本教程中,您将学习如何使用 MySQL UNIQUE
索引来防止表中的一列或多列出现重复值。
MySQL UNIQUE
索引简介
要强制执行一列或多列的唯一性值,通常使用PRIMARY KEY
约束。但是,每个表只能有一个主键。因此,如果您希望拥有多个具有唯一值的列或一组列,则不能使用主键约束。
幸运的是,MySQL 提供了另一种索引,称为UNIQUE
索引,它允许您强制一个或多个列中值的唯一性。与PRIMARY KEY
索引不同,每个表可以有多个UNIQUE
索引。
要创建UNIQUE
索引,请使用CREATE UNIQUE INDEX
语句,如下所示:
CREATE UNIQUE INDEX index_name
ON table_name(index_column_1,index_column_2,...);
Code language: SQL (Structured Query Language) (sql)
强制一个或多个列中值的唯一性的另一种方法是使用UNIQUE
约束。
当您创建UNIQUE
约束时,MySQL 在幕后创建一个UNIQUE
索引。
以下语句说明了如何在创建表时创建唯一约束。
CREATE TABLE table_name(
...
UNIQUE KEY(index_column_,index_column_2,...)
);
Code language: SQL (Structured Query Language) (sql)
在此语句中,您还可以使用UNIQUE INDEX
代替UNIQUE KEY
,因为它们是同义词。
如果要向现有表添加唯一约束,可以使用ALTER TABLE
语句,如下所示:
ALTER TABLE table_name
ADD CONSTRAINT constraint_name UNIQUE KEY(column_1,column_2,...);
Code language: SQL (Structured Query Language) (sql)
MySQL UNIQUE
索引和NULL
与其他数据库系统不同,MySQL 将NULL值视为不同的值。因此, UNIQUE
索引中可以有多个 NULL 值。
MySQL 就是这样设计的。尽管它被报告为错误,但它不是错误。
另一个重要的一点是, UNIQUE
约束不适用于除 BDB存储引擎之外的 NULL 值。
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)
);
Code language: SQL (Structured Query Language) (sql)
如果使用SHOW INDEXES
语句,您将看到 MySQL 为email
列创建了一个UNIQUE
索引。
SHOW INDEXES FROM contacts;
Code language: SQL (Structured Query Language) (sql)
让我们在contacts
表中插入一行。
INSERT INTO contacts(first_name,last_name,phone,email)
VALUES('John','Doe','(408)-999-9765','john.doe@mysqltutorial.org');
Code language: SQL (Structured Query Language) (sql)
现在,如果您尝试插入电子邮件为john.doe@mysqltutorial.org
的行,您将收到一条错误消息。
INSERT INTO contacts(first_name,last_name,phone,email)
VALUES('Johny','Doe','(408)-999-4321','john.doe@mysqltutorial.org');
Code language: SQL (Structured Query Language) (sql)
Error Code: 1062. Duplicate entry 'john.doe@mysqltutorial.org' for key 'unique_email'
Code language: SQL (Structured Query Language) (sql)
假设您希望first_name
、 last_name
和phone
的组合在联系人中也是唯一的。在这种情况下,您可以使用CREATE INDEX
语句为这些列创建UNIQUE
索引,如下所示:
CREATE UNIQUE INDEX idx_name_phone
ON contacts(first_name,last_name,phone);
Code language: SQL (Structured Query Language) (sql)
将以下行添加到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');
Code language: SQL (Structured Query Language) (sql)
Error Code: 1062. Duplicate entry 'john-doe-(408)-999-9765' for key 'idx_name_phone'
Code language: SQL (Structured Query Language) (sql)
在本教程中,您学习了如何使用 MySQL UNIQUE
索引来防止数据库中出现重复值。