小米技术社区
小米技术社区管理员 关于小米

27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]

E-mail:mzze@163.com

Q Q:32362389

W X:xiaomi168527

小米技术社区大牛王飞 关于王飞

27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]

E-mail:wf_live@126.com

Q Q:3940019

微博:王小贱ss

小米技术社区设计小艳 关于小艳

大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]

E-mail:97157726@qq.com

Q Q:97157726

标签云
精品推荐
您的位置:首页 > 后端编程 > 数据库 > mysql

mysql的唯一键unique,它的作用?和主键有什么不同?如何修改,查看,删除唯一键

分类: mysql63个赞

MySQL 唯一键约束(Unique Key)是指所有记录中字段的值不能重复出现。

例如,为 id 字段加上唯一性约束后,每条记录的 id 值都是唯一的,不能出现重复的情况。如果其中一条记录的 id 值为‘0001’,那么该表中就不能出现另一条记录的 id 值也为‘0001’。


唯一键和主键的区别:

相同性:

唯一键约束与主键约束相似的是它们都可以确保列的唯一性。

不同性:

唯一约束在一个表中可有多个,而主键只能有一个,

并且设置唯一约束的列允许有空值,但是只能有一个空值。但主键不允许有空值。


可以通过以下表来看唯一建和主键的区别:

区别
主键

1、不能重复,不能为空

2、一个表只能有1个

唯一键

1、不能重复,可以为空(只能有1个,有2个空值就重复了)

2、一个表可以有多个唯一键

拓展阅读:

mysql的自动增长auto_increment;开始值更改,每次自增量更改

mysql主键primary key和联合主键,它们的特点,作用和选用原则


使用场景

在用户信息表中,为了避免表中用户名重名,可以把用户名设置为唯一约束。

语法

unique 或 unique(字段名)
unique 或 unique key 是一样的

案例

-- 创建表的时候创建唯一键 
mysql> create table stu26(
    -> id int auto_increment primary key,
    -> name varchar(20) unique    -- 唯一键
    -> );
Query OK, 0 rows affected (0.05 sec)

-- 方法二 
mysql> create table stu27(
    -> id int primary key,
    -> name varchar(20),
    -> unique(name)
    -> );
Query OK, 0 rows affected (0.05 sec)


通过修改表修改唯一键

语法:

alter table 表名 add unique(字段名);  
alter table 表名 add unique(字段名1),add unique(字段名2);

案例:

-- 将name设为唯一键
mysql> alter table stu28 add unique(name);  


-- 将name,addr设为唯一键
mysql> alter table stu28 add unique(name),add unique(addr);
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0

mysql> desc stu28;
+-------+-------------+------+-----+---------+-------+
| Field | Type        | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+-------+
| id    | int(11)     | NO   | PRI | NULL    |       |
| name  | varchar(20) | YES  | UNI | NULL    |       |
| addr  | varchar(20) | YES  | UNI | NULL    |       |
+-------+-------------+------+-----+---------+-------+
3 rows in set (0.02 sec)


查看唯一键

通过show create table 查看唯一键的名字

用show create table查看唯一键


删除唯一键

通过唯一键的名字删除唯一键

语法:

drop index
alter table 表名 drop index 唯一键名;

案例:

mysql> alter table stu28 drop index name;
Query OK, 0 rows affected (0.00 sec)
Records: 0  Duplicates: 0  Warnings: 0


小米技术社区