博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
高性能的MySQL(5)索引策略-索引和表的维护
阅读量:6340 次
发布时间:2019-06-22

本文共 1415 字,大约阅读时间需要 4 分钟。

维护表有三个主要的目的:

1、找到并修复损坏的表

对于MyISAM存储引擎来说,表损坏通常是系统崩溃导致的。其他的引擎也会由于硬件的问题,MySQL本身的缺陷或者操作系统的问题导致索引的损坏。

损坏的索引,会导致查询返回错误的结果或者莫须有的主键冲突等问题,严重时还会导致数据库崩溃。

这类情况,可以尝试check table来检查是否发生了表损坏,有些存储引擎不支持这个命令。

可以使用repair table 来修复损坏的表,但同样不是所有引擎都支持该命令。

如果引擎不支持,可以使用alter操作重建表,或者将数据导出然后再重新导入。

InnoDB一般不会损坏,如果发生损坏,一般要么是数据库硬件问题,例如内存或者磁盘问题,要么就是数据库管理员操作导致。

常见的错误是由于尝试使用rsync备份InnoDB导致的。

如果是某条查询导致的,那一定是遇到了bug,而不是查询的问题。

2、维护准确的索引统计信息。

MySQL的查询优化器会通过2个API来了解存储引擎的索引值的分布信息,以决定如何使用索引。

第一个API是records_in_range(),通过向存储引擎传入两个边界值获取在这个范围大概有多少条记录。

对于某些引擎,该接口返回精确值,比方说MyISAM;对于InnoDB则是一个估算的值。

第二个API是info(),该接口返回各种类型的数据,包括索引的基数。

当返回信息不准确的时候,优化器会使用索引统计信息来估算扫描行数。如果表没有统计信息,或者统计信息不准确,优化器很可能做出错误的决定。

可以运行analyze table 来重新生成统计信息。

Memory引擎不存储索引统计信息

MyISAM将索引统计信息存储在磁盘中,analyze table 需要进行一次全表扫描,整个过程需要锁表。

MySQL5.5以后,InnoDB也不在磁盘存储索引统计信息,而是通过随机的索引访问来进行评估并存储在内存中。

使用show index from 命令可以察看索引基数(Cardinality)

InnoDB会在首次打开表,或者执行analyze table,或者表大小发生变化超过1/16或show table status,或show index时候都会计算索引的统计信息,如果服务器有大量的数据,这会是个严重的问题,只要show index查看索引统计信息就一定会触发统计信息更新,可以关闭

innodb_stats_on_metadata参数来关闭。

一旦关闭自动更新,那么需要周期性的使用analyze table 来手动更新,否则问题大了。

3、减少索引和数据碎片

B-Tree索引可能会碎片化,这会降低查询效率。碎片化的索引可能会以很差或者无序的方式存储在磁盘上。

可以通过optimize table 或者导出再导入的方式来重新整理数据。

对于不支持optimize table 的存储引擎,可以通过一个不做任何操作的alter table来重建表。

1
alter 
table 
<
table
> engine=<engine>;

也可以先删除索引,重建表,最后重新创建索引来实现。

索引的介绍就先到这里了,明天进入查询性能优化部分!

本文转自shayang8851CTO博客,原文链接:http://blog.51cto.com/janephp/1314057,如需转载请自行联系原作者

你可能感兴趣的文章
【crunch bang】增加壁纸图片文件
查看>>
javascript 匿名函数的理解,js括号中括function 如(function(){})
查看>>
微信二维码扫描无法下载APK文件的解决办法
查看>>
全栈工程师就是一棵歪脖子树
查看>>
Linux设置IP
查看>>
浅谈算法和数据结构: 五 优先级队列与堆排序
查看>>
Android中include标签的使用
查看>>
IOS NSPredicate 查询、搜索
查看>>
oracle查询前10条记录
查看>>
JS、C# 去除html标签
查看>>
通过命令给Linux(CentOS)分区
查看>>
如何在VMware中安装Windows Phone SDK 8.0 (支持模拟器调试)
查看>>
在ubuntu下手机无法挂载的问题
查看>>
Windows Phone开发-开发环境和结构
查看>>
scanf printf sprintf fprintf
查看>>
如何延长windows评估版的方法
查看>>
c# 自定义类型的DataBindings
查看>>
C++ Primer 学习笔记_45_STL实践与分析(19)--泛型算法的结构
查看>>
android:inputType参数类型说明
查看>>
A/C模式 是什么意思啊汽车知识问题_PCauto快问
查看>>