如何在 MySQL 中使现有字段唯一?

mysqlmysqli database

要使现有字段在 MySQL 中唯一,我们可以使用 ALTER 命令并为该字段设置 UNIQUE 约束。让我们看一个例子。首先,我们将创建一个表。

mysql> create table AddingUnique
   -> (
   -> Id int,
   -> name varchar(100)
   -> );
Query OK, 0 rows affected (0.44 sec)

将 UNIQUE 添加到现有字段的语法。

alter table yourTableName add UNIQUE(yourColumnName);

应用上述语法将 UNIQUE 添加到列"name"。

mysql> alter table AddingUnique add UNIQUE(name);
Query OK, 0 rows affected (0.60 sec)
Records: 0  Duplicates: 0  Warnings: 0

现在我们无法将重复记录插入表中,因为我们已将字段设置为唯一。如果我们尝试添加重复记录,则会引发错误。

mysql> alter table AddingUnique add UNIQUE(name);
Query OK, 0 rows affected (0.60 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> insert into AddingUnique values(1,'John');
Query OK, 1 row affected (0.15 sec)

mysql> insert into AddingUnique values(1,'John');
ERROR 1062 (23000): Duplicate entry 'John' for key 'name'

mysql> insert into AddingUnique values(2,'Carol');
Query OK, 1 row affected (0.18 sec)

mysql> insert into AddingUnique values(3,'John');
ERROR 1062 (23000): Duplicate entry 'John' for key 'name'

mysql> insert into AddingUnique values(4,'Smith');
Query OK, 1 row affected (0.18 sec)

显示所有记录。

mysql> select *from AddingUnique;

以下是输出。

+------+-------+
| Id   | name  |
+------+-------+
|    1 | John  |
|    2 | Carol |
|    4 | Smith |
+------+-------+
3 rows in set (0.00 sec)

相关文章