开发者社区> 问答> 正文

mysql中主键与唯一索引有什么区别?

主键也是值唯一 唯一索引也是值唯一 它两有啥区别?

展开
收起
道月芬1 2021-10-12 10:01:58 514 0
1 条回答
写回答
取消 提交回答
  • 主键是一种约束,唯一索引是一种索引,两者在本质上是不同的。

    主键创建后一定包含一个唯一性索引,唯一性索引并不一定就是主键。

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

    主键列在创建时,已经默认为非空值 + 唯一索引了。

    主键可以被其他表引用为外键,而唯一索引不能。

    一个表最多只能创建一个主键,但可以创建多个唯一索引。

    主键和唯一索引都可以有多列。

    主键更适合那些不容易更改的唯一标识,如自动递增列、身份证号等。

    在 RBO 模式下,主键的执行计划优先级要高于唯一索引。 两者可以提高查询的速度。

    2021-10-12 15:06:27
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像