MySQL - 索引

索引(index)是帮助数据库高效获取数据的数据结果。

优点:

  • 提高数据查询的效率,降低数据库的IO成本
  • 通过索引列对数据进行排序,降低数据排序的成本,降低CPU消耗

缺点:

  • 索引会占用存储空间
  • 索引大大提高了查询效率,但同时也降低了insertupdatedelete的效率

MySQL数据库支持的索引结构有很多,如:Hash索引、B+Tree索引、Full-Text索引等。平常所说的索引默认是B+Tree结构组织的索引。

语法

  • 创建索引

    sql 复制代码
    create [unique] index 索引名 on 表名(字段名...);
  • 查看索引

    sql 复制代码
    show index from 表名;
  • 删除索引

    sql 复制代码
    drop index 索引名 on 表名;
sql 复制代码
-- 创建:为tb_emp表的name字段建立一个索引
create index idx_emp_name on tb_emp(name);

-- 查询:查询 tb_emp 表的索引信息
show index from tb_emp;

-- 删除:删除 tb_emp 表中name字段的索引
drop index idx_emp_name on tb_emp;

show index from tb_emp;
  • 主键字段在建表时会自动创建主键索引
  • 添加唯一约束时,数据库实际上会添加唯一索引
相关推荐
2401_8735449212 小时前
使用XGBoost赢得Kaggle比赛
jvm·数据库·python
ruxingli12 小时前
MySQL优化
数据库·mysql
m0_5698814712 小时前
进阶技巧与底层原理
jvm·数据库·python
feng68_13 小时前
MySQL集群主从复制
linux·运维·数据库·mysql·adb
RDCJM13 小时前
redis 使用
数据库·redis·缓存
万岳科技系统开发13 小时前
教育培训系统开发正在重构培训机构的盈利结构
数据库·重构
2501_9454235413 小时前
数据分析师的Python工具箱
jvm·数据库·python
xingyynt13 小时前
【HTML+CSS】使用HTML与后端技术连接数据库
css·数据库·html
2401_8796938713 小时前
自动化与脚本
jvm·数据库·python
敬业小码哥13 小时前
记一次:sqlit3恢复database disk image is malformed
数据库·sql·sqlite3