mysql 第5.4章 索引-主键索引和非主键索引的区别 mysql 第5.4章 索引-主键索引和非主键索引的区别

2小时前

在 MySQL 中,主键索引和非主键索引(普通索引)都是用于提高查询效率的机制,但它们有不同的特性和用途。以下是它们的主要区别:

一、主键索引(Primary Key Index)

定义:主键索引是一种特殊的索引,它在表中唯一标识每一行数据。每个表只能有一个主键索引。

特性:

  • 唯一性:主键索引要求主键列的值必须唯一,不能为 NULL。

  • 自动创建:当你创建表时,如果定义了主键,MySQL 会自动创建主键索引。

  • 聚集索引:InnoDB 存储引擎中的主键索引通常是聚集索引(Clustered Index)。这意味着表的数据实际上是按主键的顺序存储在磁盘上的。其他索引会包含主键值作为其键的一部分。

  • 效率:由于主键索引是唯一的,因此在查找、插入和删除操作时具有很高的效率。

使用场景:

  • 用于唯一标识表中的每一行数据。

  • 常用于需要唯一性约束的列,如用户ID、订单号等。

示例:

CREATE TABLE users (
    id INT PRIMARY KEY,
    name VARCHAR(100)
);

二、非主键索引(普通索引)

定义:非主键索引是指除了主键索引之外的所有索引。它们用于加速对表的查询操作,但不具有主键索引的唯一性要求。

特性:

  • 非唯一性:非主键索引的列值可以重复,也可以为 NULL(除非显式指定 UNIQUE 约束)。

  • 非聚集索引:在 InnoDB 存储引擎中,非主键索引是非聚集索引(Secondary Index)。非主键索引存储的是索引列的值和主键值的组合。数据的实际存储是按主键排序的,非主键索引会通过主键来访问数据。

  • 灵活性:可以在表中创建多个非主键索引,用于加速不同的查询条件。

使用场景:

  • 用于提高特定查询条件的性能,如频繁用于 WHERE 子句中的列。

  • 当需要根据非主键列快速查找数据时使用。

示例:

CREATE INDEX idx_name ON users (name);

三、主要区别总结

唯一性:主键索引要求唯一性,非主键索引不要求唯一性。

数量:每个表只能有一个主键索引,但可以有多个非主键索引。

索引类型:主键索引通常是聚集索引,而非主键索引通常是非聚集索引。

数据存储:主键索引直接决定了表的数据存储顺序(对于 InnoDB),而非主键索引则通过主键值访问数据。

主键索引和非主键索引各有其独特的作用和适用场景。在设计数据库表时,需要根据具体的查询需求和数据特性选择合适的索引策略。

阅读 4

mysql文章
带到手机上看