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 次瀏覽

開啟你的 職業生涯

完成課程以獲得認證

開始吧
廣告