如何在 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)