MySQL 唯一索引
简介:在本教程中,您将学习如何使用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,...);在一列或多列中强制执行值唯一性的另一种方法是使用
UNIQUE
约束。
创建UNIQUE
约束时,MySQL会UNIQUE
在幕后创建索引。
以下语句说明了在创建表时如何创建唯一约束。
CREATE TABLE table_name( ... UNIQUE KEY(index_column_,index_column_2,...) );在此语句中,您还可以使用
UNIQUE INDEX
而不是UNIQUE KEY
因为它们是同义词。
如果要向现有表添加唯一约束,可以使用以下ALTER TABLE
语句:
ALTER TABLE table_name ADD CONSTRAINT constraint_name UNIQUE KEY(column_1,column_2,...);
MySQL UNIQUE Index&NULL
与其他数据库系统不同,MySQL将NULL值视为不同的值。因此,您可以在UNIQUE
索引中包含多个NULL值。
这就是MySQL的设计方式。即使它被报告为错误,它也不是错误。
另一个重要的一点是,UNIQUE
除了BDB 存储引擎之外,约束不适用于NULL值。
MySQL UNIQUE索引示例
假设您要管理应用程序中的联系人。您还希望contacts
表中每个联系人的电子邮件必须是唯一的。
要强制执行此规则,请在CREATE TABLE
语句中创建唯一约束,如下所示:
DROP TABLE contacts; 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
列创建了索引。
SHOW INDEXES FROM contacts;
+----------+------------+--------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+---------+------------+ | Table | Non_unique | Key_name | Seq_in_index | Column_name | Collation | Cardinality | Sub_part | Packed | Null | Index_type | Comment | Index_comment | Visible | Expression | +----------+------------+--------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+---------+------------+ | contacts | 0 | PRIMARY | 1 | id | A | 0 | NULL | NULL | | BTREE | | | YES | NULL | | contacts | 0 | unique_email | 1 | email | A | 0 | NULL | NULL | | BTREE | | | YES | NULL | +----------+------------+--------------+--------------+-------------+-----------+-------------+----------+--------+------+------------+---------+---------------+---------+------------+ 2 rows in set (0.04 sec)让我们在
contacts
表格中插入一行。
INSERT INTO contacts(first_name,last_name,phone,email) VALUES('John','Doe','(408)-999-9765','john.doe@mysqltutorial.org');现在,如果您尝试插入其电子邮件所在的行
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'假设你想要的组合
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
UNIQUE
索引来防止数据库中出现重复值。