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;

注意事项

  • 主键字段,在创建表时会自动创建主键索引(主键索引的性能最强)
  • 属性添加唯一约束时,数据库也会对其添加唯一索引约束
    • 在执行完上述索引创建语句后,执行展示索引语句的运行结果如下
相关推荐
小尔¥8 分钟前
MySQL故障排查与优化
运维·数据库·mysql
rrrjqy13 分钟前
Redis常见问题(一)
数据库·redis·缓存
Humbunklung14 分钟前
WMO 天气代码(Code Table 4677)深度解析与应用报告
开发语言·数据库·python
道清茗24 分钟前
【MySQL知识点问答题】锁机制、索引优化与数据库恢复方法
数据库·mysql
hero.fei36 分钟前
排查redis出现报错ERR redis temporary failure
数据库·redis·缓存
野犬寒鸦1 小时前
MySQL复习记录Day01
数据库·后端
ward RINL1 小时前
Spring boot启动原理及相关组件
数据库·spring boot·后端
RisunJan1 小时前
Linux命令-mysqldump(MySQL数据库中备份工具)
linux·数据库·mysql
DolphinDB智臾科技1 小时前
直播回顾 | 物联网时序数据库如何驱动电力场景智能调度?
数据库·物联网·时序数据库
FinTech老王1 小时前
告别“sql_mode“噩梦:MySQL 8.0 vs 5.7兼容性全对比与升级避坑指南
android·sql·mysql