唯一索引、主键、Unique约束

本文介绍了在数据库中如何通过创建唯一索引、主键及Unique约束来确保数据的唯一性。详细解释了它们的区别与应用场景,并提供了具体的SQL示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、定义
若当前有一张Admin表,如下:
这里写图片描述

(1)唯一索引     

若要为admin_id创建唯一索引,则语句为:
Create [Unique] Index 索引名 on 表名 (列名)
create [Unique] Index IDX_admin_id on Admin(admin_id)
也可以用图形化界面,如MySQL中,设计表->索引,然后进行添加

(2)创建主键

Alter table 表名
add constraint 主键名 primary key(列名)
Alter table administer
ADD CONSTRAINT admin_id_PK PRIMARY key(admin_id)

 (3)创建约束,这个与创建主键类似

Alter table 表名
add constraint 约束名 unique(列名)
Alter table administer
ADD CONSTRAINT admin_id_UQ unique(admin_id)

什么时候创建唯一索引、主键、Unique约束?
1、主键:首先要知道候选键——一个属性或一个属性集能够唯一标识一个关系的元组而又不包含多余的属性。主键是从候选键中选择一个作为主键。比如:学校教务系统有一个学生信息表,有学号、身份证号、姓名这三个字段,学号和身份证号都能唯一标识一个学生,通常选择学号作为主键。
2、Unique约束:通常是为非主属性设置的,非主属性取值要不重复,这个时候就可以将该属性设置为Unique约束。就如上面的例子中,身份证号不是主键,但它的取值却不能重复,这种情况就必须使用Unique约束。
3、唯一索引:创建索引是为了加快检索速度,只有当经常查询索引列中的数据时,才需要在列中建立索引。索引是在磁盘上开辟一块空间,然后把列中的数据导入进去。创建唯一索引,确保数据库表中每一行数据的唯一性。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值