MySQL高级(3) 索引入门


MySQL高级(3) 索引入门

索引介绍

为什么要使用索引?

查询快

索引的概念和分类

概念

是帮助MySQL搞笑获取数据的数据结构,可以简单的理解为"排好序的快速查找数据结构".

在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某种方式引用(指向)数据,
这样就可以在这些数据结构上实现高级查找算法。这种数据结构,就是索引

简单的理解,就是使用B+树构建的一个"目录"

为什么使用B+树而不是B树?

理论上B树的查找速度要比B+树快, 但是在有限的内存中, B+树可以存储更多的数据, 这样可以提高索引的命中率, 所以MySQL选择了B+树

举例

image-20200212210624198

如图是一个B+树,非叶子节点存储的都是数据范围,只有叶子节点存储的是确切的值和对应的指针(指向物理地址),数据库执行查询时,不断的从根节点向下查找该值所在的范围,知道查找到叶子节点,然后读取相应的物理地址

一般来说索引占用内存也很大,不可能全都存储在内存中,所以索引一般以索引文件的形式存储在磁盘上

分类
聚簇索引

按照顺序排列, 如id自增的主键

非聚簇索引

不按照顺序排列, 一般在数据库中, 除了主键是聚簇索引, 其他都是非聚簇索引

单值索引

只有一个字段作为索引

唯一索引

该索引的值是唯一的(unique)

主键索引

默认主键自动创建索引

复合索引

多个字段作为索引

索引的优缺点

优点
  1. 提高了数据检索的效率,降低数据的IO成本
  2. 降低数据排序的成本,降低CPU的消耗
缺点
  1. 实际上索引也是一张表,保存了主键与索引字段,并指向实体表的记录,要占用空间
  2. 虽然大大提高了查询速度,但是会降低更新速度,如对表进行insert,updatedelete操作时,MySQL不仅要保存数据,还要保存索引



索引入门

创建的创建和删除

创建索引
  • 一般语法(最常用)
create [unique] index <索引名> on <表名>(<索引字段列表>);
# 或者
alter table <表名> add index <索引名> (<索引字段列表>);

举例

create index idx_age_dep_name on emp(age,dep,name);
# 或者
alter table emp add index idx_age_dep_name (age,dep,name);
  • 创建一个主键索引(本质上是添加或更换一个表的主键)
alter table <表名> add primary key(&l
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL数据库是一种开源的关系型数据库管理系统,广泛应用于各种应用程序中。要从入门到精通MySQL数据库,您可以按照以下步骤进行学习: 1. 学习基本概念:了解关系型数据库的基本概念,包括表、字段、行、主键、外键等。掌握SQL语言的基本语法,包括创建表、插入数据、查询数据、更新数据和删除数据等操作。 2. 安装和配置MySQL:下载并安装MySQL数据库软件,并进行必要的配置。根据您的操作系统类型,可以选择适合的安装包和安装方法。 3. 学习SQL语言:深入学习SQL语言,包括数据定义语言(DDL)、数据操作语言(DML)、数据查询语言(DQL)和数据控制语言(DCL)等。掌握各种语句的使用方法和常见的函数。 4. 数据库设计和建模:学习如何设计和规划数据库结构,包括确定表结构、定义关系、创建索引等。了解各种数据类型和约束条件的使用。 5. 数据库操作:学习如何创建、修改和删除数据库、表和字段。掌握如何插入、更新和删除数据,以及查询数据并进行排序、过滤和分组等操作。 6. 数据库优化:了解数据库性能优化的方法和技巧,包括索引设计、查询优化、表结构调整等。学习如何监控和调优数据库性能,提高系统的响应速度和并发能力。 7. 高级特性和扩展:学习MySQL数据库高级特性,如事务处理、存储过程、触发器、视图等。了解如何进行备份和恢复数据,以及故障处理和错误调试等。 8. 实践项目:通过实践项目来巩固所学知识,例如创建一个简单的博客系统或电子商务平台。在实际应用中遇到问题时,学会查找文档和寻求帮助。 9. 持续学习和探索:MySQL数据库是一个庞大而复杂的系统,持续学习和探索新的功能和技术是提升自己的关键。阅读官方文档、参与社区讨论和参加培训课程都是不错的学习途径。 通过以上步骤的学习和实践,您可以逐步掌握MySQL数据库的基本知识和技能,并不断提升自己的水平。记得多动手实践,不断积累经验才能更好地理解和掌握MySQL数据库

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值