MySQL常见索引及其创建

MySQL索引

在 MySQL 数据库中,常见的索引类型包括以下几种:

  1. 普通索引(Normal Index):最基本的索引类型,没有任何限制。
  2. 唯一索引(Unique Index):要求索引列的值是唯一的,不允许重复。
  3. 主键索引(Primary Key Index):特殊的唯一索引,索引列的值必须唯一且不为空,用于唯一标识每行数据。
  4. 全文索引(Fulltext Index):用于全文搜索的索引类型,适合在文本字段上进行搜索。
  5. 组合索引(Composite Index):将多个列组合在一起创建的索引,可以提高多列条件查询的性能。

下面分别展示如何在 MySQL 中创建这些不同类型的索引:

1. 创建普通索引

复制代码
CREATE INDEX idx_name ON table_name (column_name);

2. 创建唯一索引

复制代码
CREATE UNIQUE INDEX idx_name ON table_name (column_name);

3. 创建主键索引

  1. 在创建表时定义主键索引

    CREATE TABLE table_name (
    id INT PRIMARY KEY,
    column1 VARCHAR(50),
    column2 INT
    );

在上面的示例中,通过将 id 字段定义为 PRIMARY KEY,即可创建一个名为 id 的主键索引。

  1. 在已存在的表上添加主键索引

    ALTER TABLE table_name
    ADD PRIMARY KEY (id);

通过以上 SQL 语句,可以在已存在的表 table_name 上添加一个名为 id 的主键索引。

  1. 使用自增主键

通常情况下,在 MySQL 中创建主键索引时会使用自增字段作为主键,例如:

复制代码
CREATE TABLE `table_name` (
    `id` INT AUTO_INCREMENT PRIMARY KEY,
    `column1` VARCHAR(50),
    `column2` INT
);

在上面的示例中,id 字段是一个自增主键,同时也是表的主键索引。

4. 创建全文索引

复制代码
CREATE FULLTEXT INDEX idx_name ON table_name (column_name);

5. 创建组合索引

复制代码
CREATE INDEX idx_name ON table_name (column1, column2);
相关推荐
kimble_xia@oracle8 分钟前
SQL 笔记
java·数据库·oracle
树谷-胡老师1 小时前
公元前3400年至公元2024年全球国家地理边界演变数据集
数据库·arcgis·信息可视化
疯狂的Alex1 小时前
2010-2022 同等学力申硕国考:软件工程简答题真题汇总
数据库·oracle·软件工程
Qlittleboy1 小时前
tp5的tbmember表闭包查询 openid=‘abc‘ 并且(wx_unionid=null或者wx_unionid=‘‘)
数据库·sql·php
markfeng82 小时前
一文搞懂MySQL字符集
sql·mysql
躲在云朵里`2 小时前
Spring Scheduler定时任务实战:从零掌握任务调度
java·数据库·mybatis
小白不想白a2 小时前
【MySQL】常用SQL语句
数据库·sql·mysql
RestCloud2 小时前
从MySQL到StarRocks:全量与增量同步的最佳实践
数据库·mysql·api
Databend2 小时前
Databend 八月月报:向量检索重磅上线,性能飞跃几十倍
数据库
毕设源码纪师姐3 小时前
计算机毕设 java 高校机房综合管控系统 基于 SSM+Vue 的高校机房管理平台 Java+MySQL 的设备与预约全流程系统
java·mysql·课程设计