5、唯⼀约束(UNIQUEKEY)
MySQL 唯⼀约束(Unique Key)是指所有记录中字段的值不能重复出现。例如,为 id 字段加上唯⼀性约束后,每条记录的 id 值都是唯⼀的,不能出现重复的情况。如果其中⼀条记录的 id 值为‘0001’,那么该表中就不能出现另⼀条记录的 id 值也为‘0001’。
唯⼀约束与主键约束相似的是它们都可以确保列的唯⼀性。不同的是,唯⼀约束在⼀个表中可有多个,并且设置唯⼀约束的列允许有空值,但是只能有⼀个空值。⽽主键约束在⼀个表中只能有⼀个,且不允许有空值。⽐如,在⽤户信息表中,为了避免表中⽤户名重名,可以把⽤户名设置为唯⼀约束。
在创建表时设置唯⼀约束
唯⼀约束可以在创建表时直接设置,通常设置在除了主键以外的其它列上。
在定义完列之后直接使⽤ UNIQUE 关键字指定唯⼀约束,语法格式如下:
<;字段名><;数据类型>UNIQUE
例 1
创建数据表 tb_dept2,指定部门的名称唯⼀,SQL 语句和运⾏结果如下所⽰。
mysql>CREATE TABLE tb_dept2
->(
-> id INT(11)PRIMARY KEY,
-> name VARCHAR(22)UNIQUE,
-> location VARCHAR(50)
->);
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||
+----------+-------------+------+-----+---------+-------+
在修改表时添加唯⼀约束
在修改表时添加唯⼀约束的语法格式为:
ALTER TABLE<;数据表名>ADD CONSTRAINT<;唯⼀约束名>UNIQUE(<;列名>);
例 2
修改数据表 tb_dept1,指定部门的名称唯⼀,SQL 语句和运⾏结果如下所⽰。
mysql>ALTER TABLE tb_dept1
->ADD CONSTRAINT unique_name UNIQUE(name);
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||
+----------+-------------+------+-----+---------+-------+
删除唯⼀约束
在 MySQL 中删除唯⼀约束的语法格式如下:
ALTER TABLE<;表名>DROP INDEX<;唯⼀约束名>;
例 3
删除数据表 tb_dept1 中的唯⼀约束 unique_name,SQL 语句和运⾏结果如下所⽰。
mysql>ALTER TABLE tb_dept1
->DROP INDEX unique_name;
mysql>DESC tb_dept1;
+----------+-------------+------+-----+---------+-------+
| Field    |Type|Null|Key|Default| Extra |
+----------+-------------+------+-----+---------+-------+
mysql删除重复的数据保留一条| id      |int(11)|NO| PRI |NULL||
| name    |varchar(22)|NO||NULL||
| location |varchar(50)| YES  ||NULL||
+----------+-------------+------+-----+---------+-------+

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。