MySQL UNIQUE 声明如何防止插入重复值?


以下是 MySQL 中 UNIQUE 子句的声明 −

create table yourTableName
(
   yourColumnName1 dataType,
   yourColumnName2 dataType,
   UNIQUE(yourColumnName1),
   UNIQUE(yourColumnName1)
);

我们首先创建一个表 −

mysql> create table DemoTable
(
   Value int,
   Value2 int,
   UNIQUE(Value),
   UNIQUE(Value2)
);
Query OK, 0 rows affected (13.98 sec)

使用 insert 命令在表中插入一些记录。此处,将不会插入重复记录,因为我们在上方使用了 UNIQUE −

mysql> insert into DemoTable values(10,20) ;
Query OK, 1 row affected (0.32 sec)
mysql> insert into DemoTable values(10,30);
ERROR 1062 (23000): Duplicate entry '10' for key 'Value'
mysql> insert into DemoTable values(40,20);
ERROR 1062 (23000): Duplicate entry '20' for key 'Value2'
mysql> insert into DemoTable values(60,70);
Query OK, 1 row affected (1.37 sec)

使用 select 语句显示表中的所有记录 −

mysql> select *from DemoTable;

这将生成以下输出 −

+-------+--------+
| Value | Value2 |
+-------+--------+
|    10 |     20 |
|    60 |     70 |
+-------+--------+
2 rows in set (0.00 sec)

更新日期: 30-Sep-2019

209 次浏览

开启你的 职业生涯

完成课程以获得认证

开始吧
广告