当前位置: 首页 > news >正文

企业手机端网站模板优化王

企业手机端网站模板,优化王,哪里有零基础网站建设教学培训,wordpress缩略图加载慢记录MySQL学习笔记,大部分图片来自黑马程序员MySQL教程。 文章目录 概述索引结构BTree为什么InnoDB使用BTree索引结构? 索引分类索引语法SQL性能分析1、查看执行频次2、慢查询日志3、profile详情4、explain执行计划 索引使用最左前缀法则索引失效情况1、…

记录MySQL学习笔记,大部分图片来自黑马程序员MySQL教程。

文章目录

  • 概述
  • 索引结构
    • B+Tree
    • 为什么InnoDB使用B+Tree索引结构?
  • 索引分类
  • 索引语法
  • SQL性能分析
    • 1、查看执行频次
    • 2、慢查询日志
    • 3、profile详情
    • 4、explain执行计划
  • 索引使用
    • 最左前缀法则
    • 索引失效情况
      • 1、范围查询
      • 2、索引列运算
      • 3、字符串不加单引号
      • 4、模糊查询
      • 5、or连接的条件
      • 6、数据分布
    • SQL提示
    • 覆盖索引
    • 前缀索引
    • 单列索引和联合索引
    • 索引设计原则
    • 总结

概述

索引是MySQL高效获取数据的数据结构,这些数据结构利用特定查找算法引用(指向)数据。

优缺点:

优点缺点
提高数据检索效率,降低IO成本需要占用空间
索引列对数据进行排序,降低了数据排序的成本,减少CPU消耗因为更新表的时候也要更新索引,所以降低了更新表的速度

但是现在磁盘很便宜,且正常情况下增删改数据库的频率很小,所以以上劣势可以忽略。

索引结构

MySQL的索引是在存储引擎层实现的,不同的存储引擎有不同的结构,主要的几种结构如下所示。

索引结构描述
B+Tree索引(重点)最常见
Hash索引底层数据结构用哈希表实现,不支持范围查询
R-Tree(空间索引)是MyISAM引擎的一个特殊索引类型,主要用于地理空间数据类型
Full-text(全文索引)一种通过建立倒排索引,快速匹配文档的索引

B+Tree

Q:为什么使用B+树?
A:针对数据库数据量大且其他树形结构的闭端,权衡下采用B+树。

在这里插入图片描述
图片来自黑马程序员MySQL教程。

在这里插入图片描述
中间元素向上分裂

在这里插入图片描述
所有元素都会出现在叶子节点,叶子节点形成一个单向链表。

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

为什么InnoDB使用B+Tree索引结构?

  • 相较于二叉树 (红黑树) ,层级更少,搜索效率高。
  • 对于B树,无论叶子节点还是非叶子节点都会保存数据,而每一个节点都存放在一个页中(页的大小是固定的),这样导致一页中存储的键值减少,指针也跟着减少,所以保存大量数据时,树的高度就会增加,查找性能降低。
  • B+树叶子节点的双向链表便于范围搜索和排序。
  • 相较于哈希索引,B+树支持范围匹配和排序操作。

索引分类

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

聚集索引叶子节点存放数一行数据,二级索引叶子节点存放主键值。
在这里插入图片描述回表查询:先在二级索引当中找到主键值,再根据主键值到聚集索引中找到这一行数据。

在这里插入图片描述
即使存储两千多万行数据,B+树的高度也只有3,所以B+树的效率很高,如果B+树的高度要大于3了,就会用分表解决。

索引语法

在这里插入图片描述

SQL性能分析

1、查看执行频次

在这里插入图片描述
七个下划线,恰好可以代表_delete、_insert、_select、_update。

2、慢查询日志

在这里插入图片描述

通过指令查看

show variables like 'slow_%';

3、profile详情

在这里插入图片描述
在这里插入图片描述

4、explain执行计划

尽量优化type。

但仅当查询不需要访问表时才会出现NULL,只访问系统表才能达到system,所以尽量往const上优化(即使用主键或者唯一索引),当使用非唯一索引的时候 type 是ref,all代表全表扫描,性能最差,index代表用了索引,但遍历了整个索引,性能也不高。

在这里插入图片描述

在这里插入图片描述

索引使用

在这里插入图片描述

最左前缀法则

在这里插入图片描述

  • 若跳过了某一列,则从这一列开始,之后的索引失效。
  • 每一列的使用顺序不影响结果。

索引失效情况

1、范围查询

在这里插入图片描述

  • 解决方法:将 < , > 改为 <= , >=

2、索引列运算

在这里插入图片描述

3、字符串不加单引号

在这里插入图片描述

4、模糊查询

like '计算机科学%' -- 不失效like '%与技术' -- 失效 like '%与%' -- 失效

5、or连接的条件

用or分隔开的条件,如果or之前的条件中的列有索引,而后面的列中没有索引,那么涉及到的索引都不会用到。
在这里插入图片描述
age没有单独建立索引,并且也不是联合索引的第一个,所以查询的时候没有索引。

6、数据分布

如果MySQL评估使用索引比不使用还要慢,则不使用索引。
在这里插入图片描述

  • is null 走不走索引取决于查询的字段中null的个数占总行数的比例。

SQL提示

在这里插入图片描述

  • 用use指定,MySQL会自己评估可能不用,用force指定,系统则只能用这个索引。

覆盖索引

在这里插入图片描述
在这里插入图片描述

  • 找gender的时候需要回表。
  • 使用select * 很容易就会回表查询。

在这里插入图片描述

  • 对username和password建立联合索引,username是第一个,那么查询的时候走联合查询,叶子节点上就是主键id,满足覆盖索引。

前缀索引

在这里插入图片描述

  • 不可能返回一个前缀,所以查询前缀肯定要回表。

单列索引和联合索引

在这里插入图片描述
在这里插入图片描述

索引设计原则

在这里插入图片描述

  • 一张表数据量超过100万就算大,如果不怎么查询,建立索引也没用;

总结

在这里插入图片描述
在这里插入图片描述

http://www.hkea.cn/news/921505/

相关文章:

  • 源码资源国内专业seo公司
  • 丽水微信网站建设报价免费精准客源
  • 广东建设工程中标公示网站google搜索引擎优化
  • 南宁老牌网站建设公司正版google下载
  • 网站做信用认证有必要吗微信朋友圈推广平台
  • 电子政务网站建设要求百度关键词规划师
  • 博客网站开发毕设免费大数据分析网站
  • 深圳教育平台网站建设好消息疫情要结束了
  • 国外设计文章的网站淘宝代运营靠谱吗
  • 市桥网站建设sem论坛
  • 猎头公司是做什么的可靠吗排名优化外包公司
  • 扶贫网站建设关键词查询神器
  • 沈阳酒店企业网站制作公司2023年9月疫情又开始了吗
  • 厦门专业网站建设如何快速推广一个新产品
  • 帮人做传销网站违法吗seo网站排名助手
  • 如何做优品快报下的子网站营销型网站建设目标
  • 用织梦做网站调用乱码营业推广是什么意思
  • 做走私网站北京口碑最好的it培训机构
  • 网站建设OA系统开发it培训机构哪家好
  • 网站运维可以做哪些域名查询网站入口
  • 网站开发的基本语言外贸平台自建站
  • 女生自己做网站营销方法有哪些
  • 怎么自己做网站吓别人金融网站推广圳seo公司
  • 彩票网站的客服有做吗海淀seo搜索优化多少钱
  • 河源哪有做网站网页模板设计
  • 手机网站可以做英文版本吗近三天时政热点
  • 怎么做网站游戏网络优化排名培训
  • ic外贸网站建设黑帽seo技巧
  • 实业有限公司网站怎么做百度一下了你就知道官网
  • 企业电子商务网站推广平台有哪些渠道