MySQL重建表统计信息


背景

最近一段时间遇到了一些性能问题
发现很多其实都是由于 数据库的索引/统计信息不准确导致的问题.
Oracle和SQLServer都遇到了很多类似的问题. 我这边联想到 MySQL也经常会出现卡顿的问题,
所以想验证一下 MySQL如果重建表索引后不知道会不会好一些.

重建的方法

MySQL官方资料里面最简单的重建方法是:
alter table tablename engine=innodb ; 网上有很多来源:
https://geek-docs.com/mysql/mysql-ask-answer/356_mysql_how_can_i_rebuild_indexes_and_update_stats_in_mysql_innodb.html
https://dev.mysql.com/doc/refman/8.0/en/rebuilding-tables.html 感觉如果写SQL的话太麻烦了. 不如一个命令直接执行. mysql -uroot -pTestxxxx -D myapp2206mysql0721 <<EOS
SELECT CONCAT('ALTER TABLE ', table_name , ' ENGINE=INNODB ;') FROM information_schema.tables WHERE table_schema="myapp2206mysql0721" and table_type='BASE TABLE' INTO OUTFILE '/tmp/mysqlrebuild.sql' ;
source /tmp/mysqlrebuild.sql
EOS 可以通过这个命令直接执行数据库的表重建动作. 需要注意 ,需要先修改一下 my.conf 增加上可以进行 into outfile的处理参数
secure_file_priv = /tmp/ 修改完成后需要重启数据库.

关于数据库表的区别

PG数据库所有的表都是 堆组织表, 又称之为 HOT PG仅支持堆表
Oracle和SQLServer 其实大部分都是 堆组织表, 但是他们也支持堆组织表和局促表等存储模式
MySQL数据库的innodb存储引擎不支持堆表, 仅支持索引组织表 也就是IOT 这两种表的存储模式各有优缺点
堆表(heap table)和索引组织表(Index Oragnization Table,简称IOT)是两种数据表的存储结构。
pg中的表是堆表。mysql Innodb引擎中的表是索引组织表。oracle中既支持堆表,也支持索引组织表。 在具体介绍堆表和索引组织表之前,我们先看下pg中index scan和index only scan。
Index Scan: 也即普通索引扫描,对于给定的查询,我们先扫描一遍索引,从索引中找到符合要求的记录的位置(指针),
再定位到表中具体的Page去取。等于是两次I/O,先走索引,再取表记录。
Index only scan: 建立index时,所包含的字段集合,囊括了我们需要查询的字段,
这样就只需在索引中取数据,就不必访问表了。 索引组织表有些明显的好处:
一是节约了磁盘空间,
二是降低了IO,提高了查询的性能。
尤其是当我们的数据几乎总是通过主键来进行搜索时,查询效率的提升将会很显著。 缺点: 当索引组织表上有二级索引,并且频繁使用二级索引进行访问时,它的缺点也很明显了,
那就是二级索引需要回表,它的效率要比堆表直接使用行指针访问数据的效率要低的。 总结一下: 堆表:数据存储在表中,索引存储在索引里,两者分开的。数据在堆中是无序的,
索引让键值有序,但数据还是无序的。堆表中主键索引和普通索引一样的,都是存放指向堆表中数据的指针。 索引组织表:数据存储在聚簇索引中,或者说,数据按照主键的顺序来组织数据,两者合二为一。
主键索引,叶子节点存放整行数据。其他索引称为辅助索引(二级索引),叶子节点存放键值和主键值。 来源: https://www.modb.pro/db/107906

MySQL重建表统计信息的更多相关文章

  1. MySQL InnoDB配置统计信息

    MySQL InnoDB配置统计信息 1. 配置持久化(Persistent)统计信息参数 1.1 配置自动触发更新统计信息参数 1.2 配置每张表的统计参数 1.3 配置InnoDB优化器统计信息的 ...

  2. SQL调优--记一次表统计信息未及时更新导致查询超级慢

                某日同事丢给我一个看上去复杂的查询(实际就涉及两张表,套来套去)说只是换了日期条件,但一个查询5秒出数据,一个根本查不出来.现在整理下解决过程,及涉及的知识点. 若有不正之处, ...

  3. MySQL--查询表统计信息

    ============================================================= 可以用show table status 来查看表的信息,如:show ta ...

  4. db2重组所有表和更新表统计信息

    1.构建db2admin模式下的所有表的重组语句: select ' reorg table '||TABLE_NAME||';' from sysibm.tables where  TABLE_SC ...

  5. mysql获取表列信息、主键信息

    /** * 获取物理表中已存在的列信息 * @param tbName 表名 * @return results 查询结果 */ fun getExistColumnInfo(tbName:Strin ...

  6. 查询mysql数据库表的信息(表大小、数据大小、索引大小)

    select * from information_schema.TABLES where information_schema.TABLES.TABLE_SCHEMA='databasename' ...

  7. 表统计信息(storge)相关

    select t1.NUM_ROWS,t1.BLOCKS,t1.EMPTY_BLOCKS,t1.AVG_SPACE,t1.CHAIN_CNT,t1.AVG_ROW_LEN from user_tab_ ...

  8. Mysql一个表编码的坑,mark一下

    问题:一个sql执行很慢,5分钟左右,关键是最大的表是5万出头,另一张表不到5000原因:是两个表的字符集不同,导致匹配时,没有匹配到 解决办法:将两个表的字符集改成一样具体的命令: ALTER TA ...

  9. SQL2008R2的 遍历所有表更新统计信息 和 索引重建

    [2.以下是更新统计信息] DECLARE UpdateStatisticsTables CURSOR READ_ONLY FOR SELECT sst.name, Schema_name(sst.s ...

  10. MySQL统计信息以及执行计划预估方式初探

    数据库中的统计信息在不同(精确)程度上描述了表中数据的分布情况,执行计划通过统计信息获取符合查询条件的数据大小(行数),来指导执行计划的生成.在以Oracle和SQLServer为代表的商业数据库,和 ...

随机推荐

  1. Vue.js 原理分析

    本文内容提炼于<Vue.js设计与实现>,全书共 501 页,对 Vue.js 的设计原理从 0 到 1,循序渐进的讲解. 篇幅比较长,需要花些时间慢慢阅读,在合适的位置会给出在线示例以供 ...

  2. 2023“强网杯”部分WP

    强网先锋 SpeedUp 题目 我的解答: 分析代码可知是求2的27次方的阶乘的每一位的和. 使用在线网址直接查看:https://oeis.org/A244060/list 然后sha256加密 f ...

  3. 文心一言 VS 讯飞星火 VS chatgpt (43)-- 算法导论5.4 7题

    七.为使特征序列长度的下界变得更精确,请说明在 n 次硬币的公平抛掷中,不出现比Ign - 2lglgn 更长的连续正面特征序列的概率小于 1/n. 文心一言: 在 n 次硬币的公平抛掷中,每个硬币正 ...

  4. hutool的常用方法

    https://www.hutool.cn/docs/#/ 官方文档 Hutool 是一个 Java 开发工具包,提供了丰富实用的工具类,包括字符串处理.日期处理.文件操作.加密解密.网络请求等等.以 ...

  5. RT-DETR:可以满足实时性要求的DETR模型

    本文分享自华为云社区<高性能网络设计秘笈:深入剖析Linux网络IO与epoll>,作者: Lion Long . 一.epoll简介 epoll是Linux内核中一种可扩展的IO事件处理 ...

  6. MySQL数据库事务隔离性的实现

    摘要:事实上在数据库引擎的实现中并不能实现完全的事务隔离,比如串行化. 本文分享自华为云社区<[数据库事务与锁机制]- 事务隔离的实现>,原文作者:技术火炬手 . 事实上在数据库引擎的实现 ...

  7. Java中观察者模式与委托,还在傻傻分不清

    摘要:本文通过对比Java中观察者模式与委托,希望能够让开发者分清二者的区别和联系. 本文分享自华为云社区<Java中观察者模式与委托的对比>,作者: 小小张自由--张有博 . 代码背景 ...

  8. 华为AppCube入选Forrester《中国低代码平台市场分析报告》

    摘要:知名研究与分析机构Forrester于11月11日发布<中国低代码平台市场分析报告(The State Of Low-Code Platforms In China)>,AppCub ...

  9. 结MySQL 的一些知识点:MySQL 安装

    MySQL 安装 所有平台的 MySQL 下载地址为: MySQL 下载 . 挑选你需要的 MySQL Community Server 版本及对应的平台. **注意:**安装过程我们需要通过开启管理 ...

  10. Solon 开发进阶,一、插件扩展机制

    Solon 开发进阶 一.插件扩展机制 二.体外扩展机制 三.常用配置说明 四.启动参数说明 五.全局异常订阅 像 @Tran.@Cache 之类的注解开发成果,都会希望能在所有项目中复用.Solon ...