加入收藏 | 设为首页 | 会员中心 | 我要投稿 好传媒网 (https://www.haochuanmei.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql唯一索引和主键的差别是什么

发布时间:2022-02-10 23:48:57 所属栏目:MySql教程 来源:互联网
导读:本篇内容介绍了mysql唯一索引和主键的区别是什么的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! 区别:1、主键是一种约束,唯一索引是一种索引;2、
      本篇内容介绍了“mysql唯一索引和主键的区别是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
  
     区别:1、主键是一种约束,唯一索引是一种索引;2、主键创建后一定包含一个唯一性索引,唯一性索引不一定是主键;3、唯一性索引列允许空值, 主键不允许;4、主键可被其他表引为外键,唯一索引不能;5、一个表只能创建一个主键,但可创建多个唯一索引。
 
本教程操作环境:windows10系统、mysql8版本、Dell G3电脑。
 
主键(PRIMARY KEY)的完整称呼是“主键约束”,是 MySQL 中使用最为频繁的约束。一般情况下,为了便于 DBMS 更快的查找到表中的记录,都会在表中设置一个主键。
 
主键分为单字段主键和多字段联合主键,本节将分别讲解这两种主键约束的创建、修改和删除。
 
使用主键应注意以下几点:
 
每个表只能定义一个主键。
主键值必须唯一标识表中的每一行,且不能为 NULL,即表中不可能存在有相同主键值的两行数据。这是唯一性原则。
一个字段名只能在联合主键字段表中出现一次。
联合主键不能包含不必要的多余字段。当把联合主键的某一字段删除后,如果剩下的字段构成的主键仍然满足唯一性原则,那么这个联合主键是不正确的。这是最小化原则。
主键和唯一索引的区别
 
1、主键是一种约束,唯一索引是一种索引,两者在本质上是不同的。
 
2、主键创建后一定包含一个唯一性索引,唯一性索引不一定就是主键。
 
3、唯一性索引列允许空值, 而主键列不允许为空值。
 
4、主键可以被其他表引用为外键,而唯一索引不能。
 
5、 一个表最多只能创建一个主键,但是可以创建多个唯一索引。
 
6、主键更适合那些不容易改变的唯一标识,如自动递增列,身份证号等。
 
7、在RBO 模式下,主键的执行计划优先级高于唯一索引。两者可以提高查询的速度。
 
“mysql唯一索引和主键的区别是什么”的内容就介绍到这里了,感谢大家的阅读。

(编辑:好传媒网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读