mysql主键和唯一索引_主键和唯一索引的区别

前言: 作为一个非开发出身的DBA刚开始对数据库的主键、外键等一系列的词很是困惑,到后面对主键(primary key)和唯一索引(Unique Index)又迷糊了很久,后面终于陆续整理清楚了,总结和大家分享下;

一、相似之处创建主键的同时会创建一个唯一索引;

二、区别主键是一种约束,目的是对这个表的某一列进行限制;

唯一索引是一种索引,索引是数据库表的一个冗余结构,目的是为了更好的查询;

主键列不允许为空值,而唯一性索引列允许空值;

一个表最多只能一个主键,但是可以包含多个唯一索引;

三、测试

测试步骤:

3.1 创建一个表

脚本:create table john as select * from dba_objects where 1=0;(拷贝表的结构)

3.2 创建主键,检查是否产生唯一索引和约束

脚本:ALTER TABLE john ADD CONSTRAINT john_PrimaryKey PRIMARY KEY (object_id);   CREATE UNIQUE INDEX john_UniqueKey ON john  (owner);

查找语句:

SELECT table_name,table_type,index_name,index_type,uniqueness

FROM DBA_INDEXES

WHERE TABLE_NAME='JOHN';

43dc03dcdf25fc83bb79904c5283028b.png

3.3 测试再创建唯一索引和主键

ALTER TABLE john ADD CONSTRAINT john_PrimaryKey_2 PRIMARY KEY (namespace); ---会报错误ORA-02260: 表只能具有一个主键

CREATE UNIQUE INDEX john_UniqueKey_2 ON john  (timestamp); -----可以创建

d3dd70a99a77ea08f4fc395fa62d9a29.png

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

本文作者:JOHN

ORACLE技术博客:ORACLE 猎人笔记               数据库技术群:367875324 (请备注ORACLE管理 )

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值