MySQL-索引

目录

介绍

概念

优缺点

结构

语法

创建索引

查看索引

删除索引

注意事项


介绍

概念

  • 索引(index):是帮助数据库高效获取数据的数据结构

优缺点

  • 优点
    • 提高数据的查询效率,降低数据库的IO成本
    • 通过索引对数据进行排序,降低数排序的成本,降低CPU消耗
  • 缺点
    • 索引会占用内存空间
    • 索引大大提高了查询效率,同时却也降低了insert、update、delete的效率

结构

  • MySQL数据库支持的索引结构很多,如:Hash索引、B+Tree索引、Full-Text索引等。我们平常所说的索引,如果没有特别指明,都是默认B+Tree组织结构的索引
    • B+Tree(多路平衡搜索树)
      • 每一个节点可以存储多个key(有n个key,就有n个指针)

      • 所有数据都储存在叶子节点,非叶子节点仅用于索引数据

      • 叶子节点形成了一颗双向链表,便于数据的排序及区间范围的查询

语法

创建索引

  • create [unique] index 索引名 on 表名(字段名,.....);

  • on 之后指定创建索引的表与字段,加上unique表示创建唯一索引

  • 具体实例代码如下
    *

    sql 复制代码
    create index idx_emp_name on tb_emp (name);

查看索引

  • show index from 表名;

  • 查看指定表的所有索引

  • 具体实例代码如下
    *

    sql 复制代码
    show index from tb_emp;

删除索引

  • drop index 索引名 on 表名
  • 删除指定表的指定索引
  • 具体实例代码如下
sql 复制代码
drop index idx_emp_name on tb_emp;

注意事项

  • 主键字段,在创建表时会自动创建主键索引(主键索引的性能最强)
  • 属性添加唯一约束时,数据库也会对其添加唯一索引约束
    • 在执行完上述索引创建语句后,执行展示索引语句的运行结果如下
相关推荐
AllData公司负责人3 分钟前
AllData数据中台通过开源项目RustFS建设现代数据湖存储,接入工业, 医疗, 物联网数据,包括文件/图像/音频/视频数据!
数据库·数据仓库·物联网·开源·数据存储·数据接入·rustfs
m0_613856293 分钟前
html标签如何插入图片_html中img标签的正确使用方式【方法】
jvm·数据库·python
m0_596406374 分钟前
如何防止MongoDB副本集被误初始化_副本集名称(replSetName)锁定
jvm·数据库·python
DROm RAPS5 分钟前
保姆级教程 !SQL Server数据库的备份和还原
数据库·oracle
2301_775148156 分钟前
HTML函数在系统字体渲染模糊是硬件问题吗_显示输出链路排查【方法】
jvm·数据库·python
qq_349317486 分钟前
Golang怎么做API网关_Golang API网关教程【总结】
jvm·数据库·python
DevilSeagull10 分钟前
MySQL(1) 安装与配置
java·数据库·git·mysql·http·开源·github
李白客11 分钟前
高可用数据库:RTO、RPO与架构选型,一篇讲透
数据库·架构
justjinji14 分钟前
Redis如何利用LFU算法优化缓存命中率
jvm·数据库·python
瀚高PG实验室16 分钟前
PostgreSQL pg_dump对象名称中有换行符时可导致psql客户端及恢复目标服务器执行任意恶意代码HGVE-2025-E008
服务器·数据库·postgresql·瀚高数据库