唯一约束(UNIQUE_KEY)

唯一约束可以保证记录的唯一性

唯一约束的字段可以为空值(NULL)

每张数据表可以存在多个唯一约束(主键只有一个)

mysql> CREATE TABLE tb7(
-> id SMALLINT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
-> username VARCHAR(20) NOT NULL UNIQUE KEY,
-> age TINYINT UNSIGNED
-> );
Query OK, 0 rows affected (0.11 sec)

mysql> SHOW COLUMNS FROM tb7;

+----------+----------------------+------+-----+---------+----------------+
| Field         | Type                       | Null    | Key  | Default  | Extra               |
+----------+----------------------+------+-----+---------+----------------+
| id             | smallint(5) unsigned | NO     | PRI  | NULL      | auto_increment|
| username  | varchar(20)             | NO     | UNI  | NULL     |                        |
| age           | tinyint(3) unsigned   | YES   |        | NULL     |                        |
+----------+----------------------+------+-----+---------+----------------+
3 rows in set (0.04 sec)

id是自动编号的字段,所以不用赋值。

mysql> INSERT tb7(username,age) VALUES('Tom',22);
Query OK, 1 row affected (0.06 sec)

username是唯一约束,存在Tom,再赋值就会出错。

mysql> INSERT tb7(username,age) VALUES('Tom',22);
ERROR 1062 (23000): Duplicate entry 'Tom' for key 'username'

 

posted @ 2017-03-21 20:53  浅色夏沫  阅读(1751)  评论(0编辑  收藏  举报