mysql 唯一约束 多字段_mysql多字段唯一约束
MySQL唯一約束(Unique Key)要求該列唯一,允許為空,但只能出現一個空值。唯一約束可以確保一列或者幾列不出現重復值。
在創建表時設置唯一約束
在定義完列之后直接使用 UNIQUE 關鍵字指定唯一約束,語法規則如下: UNIQUE
創建數據表 tb_dept2,指定部門的名稱唯一,輸入的 SQL 語句和運行結果如下所示。mysql> CREATE TABLE tb_dept2
-> (
-> id INT(11) PRIMARY KEY,
-> name VARCHAR(22) UNIQUE,
-> location VARCHAR(50)
-> );
Query OK, 0 rows affected (0.37 sec)
mysql> DESC tb_dept2;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id | int(11) | NO | PRI | NULL | |
| name | varchar(40) | YES | UNI | NULL | |
| location | varchar(50) | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.08 sec)
提示:UNIQUE 和 PRIMARY KEY 的區別:一個表可以有多個字段聲明為 UNIQUE,但只能有一個 PRIMARY KEY 聲明;聲明為 PRIMAY KEY 的列不允許有空值,但是聲明為 UNIQUE 的字段允許空值的存在。
在修改表時添加唯一約束
在修改表時添加唯一約束的語法格式為:ALTER TABLE ADD CONSTRAINT UNIQUE();
修改數據表 tb_dept1,指定部門的名稱唯一,輸入的 SQL 語句和運行結果如下所示。mysql> ALTER TABLE tb_dept1
-> ADD CONSTRAINT unique_name UNIQUE(name);
Query OK, 0 rows affected (0.63 sec)
Records: 0 Duplicates: 0 Warnings: 0
mysql> DESC tb_dept1;
+----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+-------------+------+-----+---------+-------+
| id | int(11) | NO | PRI | NULL | |
| name | varchar(22) | NO | UNI | NULL | |
| location | varchar(50) | YES | | NULL | |
+----------+-------------+------+-----+---------+-------+
3 rows in set (0.00 sec)
假設有一個需求是用戶給評論點贊,數據庫設計是三張表,用戶表t_user,評論表t_comment,點贊表t_praise,其中點贊表中有兩個外鍵分別是user_id和comment_id,分別關聯用戶表的用戶id和評論表的評論id,然后規定一個用戶只能給同一條評論點贊一次,有一種實現方式就是在插入點贊表之前,先通過user_id和comment_id查詢是否有點贊記錄,如果沒有的話,再執行插入操作,否則返回您已經點過贊了.這樣實現的話就會多一次數據庫查詢操作.更好的實現是,修改點贊表的user_id和comment_id為唯一約束,即這兩列不能同時相同,這樣在執行插入操作的話,如果已經點過贊了,數據庫會拋出違反了唯一鍵約束,這樣的話,就可以避免多一次數據庫查詢操作了.具體設置多列為唯一約束的語句是:UNIQUE KEY (,...,)CREATE TABLE `t_praise` (
`id` int(12) unsigned NOT NULL AUTO_INCREMENT,
`comment_id` int(12) NOT NULL,
`user_id` int(12) NOT NULL,
KEY `FK_t_praise_comment` (`comment_id`),
KEY `FK_t_praise_user` (`user_id`),
UNIQUE KEY `UK_praise` (`comment_id`,`user_id`)
)
總結
以上是生活随笔為你收集整理的mysql 唯一约束 多字段_mysql多字段唯一约束的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: PID:我应该何时计算积分项?
- 下一篇: 汇编学习笔记(二):转移指令