MySQL系列之索引入门(上)

前言

在我们的日常项目或产品研发/运行过程中,是否经常遇到查询效率问题?
——答:必须的呀
但凡遇到这类问题,甲方见了直叹气,乙方见了直摇头,恨不得亲自上阵了哟~

当Table中,数据积累到一定程度,一般考虑几个优化策略:

  • 横向拆表,分而治之
  • 纵向拆表,大而化小
  • 增加索引,寻找捷径
  • 优化SQL,探索最优
  • …等等

今天博主重点讲讲其中的索引(英文:index)是如何快速定位的。Let`s Go!

在这里插入图片描述


首先,我们了解一下,MySQL有哪些索引可供选择。

一、索引简介

1. 按逻辑划分
索引类型索引名称索引说明
KEY普通索引基本索引类型,值允许重复和空
UNIQUE唯一索引值必须唯一,允许空
PRIMARY主键索引唯一索引加强版,值不允许空
FULLTEXT全文索引可以对长文本值进行分词检索,值允许重复和空
2. 按物理划分
索引类型索引特征索引说明
聚簇索引B+树,表唯一基于主键形成Tree结构存储,包含每行记录
非聚簇索引基于聚簇索引创建,允许多个对主键索引,且包含聚簇索引key

在一定程度上,聚簇索引实现了全表数据的索引化存储,其主要基于主键完成的。因此主键一般不允许变更,否则变更导致的索引代价太高。而非聚簇索引又实现了对聚簇索引的进一步索引,当然也只对主键值进行索引,它也称为辅助索引。
在这里插入图片描述

基于上图,可以理解为,如果我们使用非聚簇索引列进行查询,会多一次B+Tree的扫描。所以如何合理使用,需结合业务进行优化。

3. 按影响字段划分
索引名称索引特征索引说明
单列索引单列值对单列进行索引,比如常见的primary
组合索引多列值对多列进行索引,以组合的形式提高查询效率

结语

综上,博主从逻辑、物理、影响字段三个维度,对索引进行了剖析并加以简述,我想各位盆友应该会一目了然。数据效率是业务发展的关键,也是我们日常面对客户必须要解决的关键环节。


在这里插入图片描述

  • 8
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值