梁敬彬老师的《收获,不止SQL优化》,关于如何缩短SQL调优时间,给出了三个步骤,
梁敬彬老师的《收获,不止SQL优化》,关于如何缩短SQL调优时间,给出了三个步骤,
1. 先获取有助调优的数据库整体信息
2. 快速获取SQL运行台前信息
3. 快速获取SQL关联幕后信息
其实我们日常,这些步骤,或多或少都会用,但往往缺乏系统的梳理,想到哪儿,做到哪儿,有时还是需要方法论的指导,梁老师帮助我们整理,而且给出了一键生成的脚本,非常实用,这引出了另一个话题,正如eygle曾说的,“动手实验实证能力,才会让别人的经验成为我们的知识和技能,不断成长”,除此之外,我们不能仅仅黑盒地使用,要了解背后机制,怎么一键生成的?脚本哪儿写得好,哪儿能优化,从中我们可以学习借鉴什么,这才能充分“榨干”脚本的知识。
1. 先获取有助调优的数据库整体信息
首先要知道整个数据库的运行情况,自然想到AWR,但是不是所有的性能问题,都能通过AWR暴露,例如采集AWR时间段,有问题的SQL根本未执行,因此,没发现问题,不代表没有问题。
使用spooldb.sql脚本(链接:https://github.com/liangjingbin99/shouhuo/blob/master/%E7%AC%AC01%E7%AB%A0/spooldb.sql),可以得到下面这几个文件,
(1) 最近一小时的ADDM:addmrpt_1_576_578.txt
(2) 最近一小时的AWR:awrrpt_1_577_578.html
(3) 最近7天的AWR:awrrpt_1_576_578_all.html
(4) 最近半小时的ASH:ashrpt_1_20190317212222_20190317215222.html
(5) 数据库所有的相关信息:spool_BISAL_1_19-03-17_21.52.html
前几个好理解,最后一个,数据库所有的相关信息,是用spool生成的,包含如下信息,我们能针对自己的个性化需求,增加/修改/删除关注的相应采集项,另外,发散一些想法,这些采集项,对应的SQL,我们能融入自己的监控平台,实现自动化采集、展示,做到充分利用,
"版本
最近一次启动时间,版本,以及是否RAC
30分钟内CPU或等待最长的
近期负载情况(根据AWR快照)
逻辑读最多
物理读最多
执行次数最多
解析次数最多
磁盘排序最多
提交次数超过10000的session
长度超过100的SQL
查询共享内存占有率
表有带并行度
索引有带并行度
失效索引
失效对象
位图索引和函数索引、反向键索引
组合索引组合列超过4个的
索引个数字超过5个的
哪些大表从未建过索引。
哪些表的组合索引与单列索引存在交叉的情况。
哪些对象建在系统表空间上。
检查统计信息是否被收集
检查哪些未被收集或者很久没收集
被收集统计信息的临时表
日志切换频率分析
最近10天中每天日志切换的量
日志组大小
查看recovery_file_dest使用率
检查序列小于20的情况
表空间使用情况
整个数据库有多大
对象大小TOP10
回收站情况(大小及数量)
查谁占用了undo表空间
查谁占用了temp表空间
观察回滚段,临时段及普通段否是自动扩展
表大小超过10GB未建分区的
分区最多的前10个对象
分区不均匀的表
列数量超过100个或小于2的表
表属性是nologging的
表属性含COMPRESSION的
索引属性含COMPRESSION的
触发器
将外键未建索引的情况列出
热点块(汇总)
热点块(展开,未汇总)
附录:查看session_cached_cursors的参数设置情况,如果使用率为100%则增大这个参数值
附录:供参考的Oracle所有参数"
2. 快速获取SQL运行台前信息
针对具体SQL的调优,执行计划,是重要的武器,往往需要和运行时的统计信息结合一起看,才会更加准确。
P.S. 下面是执行计划获取的几种方法,
《一个执行计划异常变更的案例 - 外传之查询执行计划的几种方法》
3. 快速获取SQL关联幕后信息
得到SQL信息,可能需要确认和这条SQL关联的表、索引等的信息,辅助问题的判断。
为了一键得到2和3的情况,执行spoolsql.sql脚本(链接:https://github.com/liangjingbin99/shouhuo/blob/master/%E7%AC%AC02%E7%AB%A0/spoolsql.sql),输入要检索的sql_id,通过spool得到输出结果,如下,sql_id是7ng34ruy5awxq的SQL,文件名为7ng34ruy5awxq.html,
通过这两个脚本,一键生成数据库、SQL相关的统计信息,非常方便,当然,了解脚本的原理,可以让我们更有针对性地使用这些脚本,甚至改造脚本,从中借鉴学习,转化为自己的知识体系,对于个人的成长,这才是最重要的。
————————————————
版权声明:本文为CSDN博主「bisal」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/bisal/article/details/88685091
梁敬彬老师的《收获,不止SQL优化》,关于如何缩短SQL调优时间,给出了三个步骤,的更多相关文章
- SQL Server调优系列玩转篇三(利用索引提示(Hint)引导语句最大优化运行)
前言 本篇继续玩转模块的内容,关于索引在SQL Server的位置无须多言,本篇将分析如何利用Hint引导语句充分利用索引进行运行,同样,还是希望扎实掌握前面一系列的内容,才进入本模块的内容分析. 闲 ...
- 智能SQL优化工具--SQL Optimizer for SQL Server(帮助提升数据库应用程序性能,最大程度地自动优化你的SQL语句 )
SQL Optimizer for SQL Server 帮助提升数据库应用程序性能,最大程度地自动优化你的SQL语句 SQL Optimizer for SQL Server 让 SQL Serve ...
- Oracle之SQL优化专题01-查看SQL执行计划的方法
在我2014年总结的"SQL Tuning 基础概述"中,其实已经介绍了一些查看SQL执行计划的方法,但是不够系统和全面,所以本次SQL优化专题,就首先要系统的介绍一下查看SQL执 ...
- Oracle之SQL优化专题02-稳固SQL执行计划的方法
首先构建一个简单的测试用例来实际演示: create table emp as select * from scott.emp; create table dept as select * from ...
- 有史以来性价比最高最让人感动的一次数据库&SQL优化(DB & SQL TUNING)——半小时性能提升千倍
昨天,一个客户现场人员急急忙忙打电话找我,说需要帮忙调优系统,因为经常给他们干活,所以,也就没多说什么,先了解情况,据他们说,就是他们的系统最近才出现了明显的反应迟钝问题,他们的那个系统我很了解,软硬 ...
- SQL Server 调优系列玩转篇三(利用索引提示(Hint)引导语句最大优化运行)
前言 本篇继续玩转模块的内容,关于索引在SQL Server的位置无须多言,本篇将分析如何利用Hint引导语句充分利用索引进行运行,同样,还是希望扎实掌握前面一系列的内容,才进入本模块的内容分析. 闲 ...
- SQL优化的一些总结 SQL编写一般要求
SQL编写一般要求---SQL语句尽可能简单---分解联接保证高并发---同数据类型的列值比较---不在索引列做运算---禁止使用SELECT *---避免负向查询和%前缀模糊查询---保持事务(连接 ...
- SQL Server性能调优系列
这是关于SQL Server调优系列文章,以下内容基本涵盖我们日常中所写的查询运算的分解以及调优内容项,皆为原创........ 第一个基础模块注重基础内容的掌握,共分7篇文章完成,内容涵盖一系列基础 ...
- sql server性能调优
转自:https://www.cnblogs.com/woodytu/tag/%E6%80%A7%E8%83%BD%E8%B0%83%E4%BC%98%E5%9F%B9%E8%AE%AD/defaul ...
随机推荐
- iOS 弹窗alertView使用详解
转自:http://blog.it985.com/4321.html alertView是iOS自带的弹窗通知框,我们来看下默认样式的效果图 下面直接上代码 1 2 3 4 5 - (void)del ...
- Java修炼——面向对象的三大特征_多态_多态的三个必要条件
多态指的是同一个方法调用,由于对象不同可能会有不同的行为,现实生活中,同一个方法,具体实现会完全不同. 多态的要点: 1.多态是方法的多态,不是属性的多态(多态与属性无关) 2.多态的存在有三个必要条 ...
- 马拉车manacher
目的:线性查找一个串的最长回文子串 时间复杂度:O(n) len[i]表示以i为中心的回文串的半径,mx即为当前计算回文串最右边字符的最大值,p是中心点mid,mx-i和2*p-1关于p对称 http ...
- ef not in
//not in linq var xx=(from c in measStateDetail where !((from d in breakInstr select d.InstrCode).Co ...
- 回归损失函数2 : HUber loss,Log Cosh Loss,以及 Quantile Loss
均方误差(Mean Square Error,MSE)和平均绝对误差(Mean Absolute Error,MAE) 是回归中最常用的两个损失函数,但是其各有优缺点.为了避免MAE和MSE各自的优缺 ...
- CCF-CSP题解 201709-3 JSON查询
要求写一个小程序完成JSON查询的功能. 查询dfs就好了. 存储JSON对象用图(树)就好,把\(<key[],type,val[]>\)作为节点,然后又是字符串处理了. 其实就是个简化 ...
- 《MySQL数据库》MySQL数据库安装(linux)
1. 下载安装包: 百度网盘:链接: https://pan.baidu.com/s/1toGl8O9gMBpDWn0mHWwFyg 提取码: i51g 官网下载:https://dev.mysql ...
- ngxtop(nginx实时监控工具)
原文内容来自于LZ(楼主)的印象笔记,如出现排版异常或图片丢失等问题,可查看当前链接:https://app.yinxiang.com/shard/s17/nl/19391737/dea1ca3a-7 ...
- LImax服务器框架学习--安装、使用ant工具、生成limax相关代码
一.安装ant ant 是一个将软件编译.测试.部署等步骤联系在一起加以自动化的一个工具,大多用于Java环境中的软件开发.在实际软件开发中,有很多地方可以用到ant. 首先现在一个ant安装压缩包, ...
- ASP.NET操作Excel
使用NPOI操作Excel,无需Office COM组件 部分代码来自于:https://docs.microsoft.com/zh-tw/previous-versions/ee818993(v=m ...