解读 “SQL ordered by Physical Reads (UnOptimized)“

全网最全面的Oracle AWR 专栏,持续更新中...

在 Oracle AWR 报告的 "SQL Statistics" 部分中,有一个名为 "SQL ordered by Physical Reads (UnOptimized)" 的列表,它展示了在执行过程中产生未优化读请求(UnOptimized Read Requests)最多的 SQL 语句。

这个列表可以用来评估 Smart Flash Cache 或 Exadata Smart Scan 在 SQL 层面上的利用效率。

在启用了 Smart Flash Cache 的 Oracle 数据库中,每一次物理读请求(Physical Read Request)都可以被分类为:

  • Optimized Read Request:表示该读请求直接从 Smart Flash Cache(或 Exadata V2 的 Smart Flash Cache)中被满足,无需访问磁盘;
  • UnOptimized Read Request:表示该请求未被Smart Flash Cache命中,而是走了传统的磁盘 I/O 路径。

这儿有一个例子:

在这个例子中,可以看到该 SQL 一共发生了 240 次物理读请求,其中只有 30 次 是传统的物理读请求。

剩下的 210 次(240 - 30) 都由 Smart Flash Cache 优化处理,命中率为 210 ÷ 240 = 87.5%。

这意味着 Smart Flash Cache 成功地承担了该 SQL 绝大多数的 I/O 负载。

如果数据库 没有启用 Smart Flash Cache,则所有读请求都是未优化读(UnOptimized Read)。

此时,"UnOptimized Read Reqs" 与 "Physical Read Reqs" 数值完全相同;并且"%Opt" 值为 0。

因此,"SQL ordered by Physical Reads (UnOptimized)" 与 "SQL ordered by Reads" 实际上会显示相同的 SQL 列表,都是按照物理读量排序的 SQL。

即使如此,该列表依然有价值,可用于识别 I/O 负载最高的 SQL 语句。

以下是同一个 SQL 在两个列表中的表现:


这两个列表看起来非常相似,但度量的维度略有不同:

"SQL ordered by Reads" 中的 Physical Reads 表示 读取的数据块数(blocks);

"SQL ordered by Physical Reads (UnOptimized)" 中的 Physical Read Reqs 表示 I/O 请求次数(requests)。

通过对比两者,可以估算出平均每次 I/O 请求读取了多少个数据块。

在上面的例子中,两者的数值几乎一致,说明 Oracle 每次 I/O 大约只读取一个数据块(即小块 I/O 模式)

号主在certview.oracle.com网站上的证书清单截图。

关于号主,姚远:

  • Oracle ACE(Oracle和MySQL数据库方向)
  • 华为云最有价值专家
  • 《MySQL 8.0运维与优化》的作者
  • 拥有数十项数据库认证
  • 曾任IBM公司数据库部门经理
  • 20+年DBA经验,服务2万+客户
  • 精通C和Java,发明两项计算机专利
  • 两次获得国家部级奖
相关推荐
偶遇急雨洗心尘30 分钟前
记录一次服务器迁移时,数据库版本不一致导致sql函数报错和系统redirect重定向丢失域名问题
运维·服务器·数据库·sql
Arva .1 小时前
MySQL 的存储引擎
数据库·mysql
Logic1011 小时前
《Mysql数据库应用》 第2版 郭文明 实验5 存储过程与函数的构建与使用核心操作与思路解析
数据库·sql·mysql·学习笔记·计算机网络技术·形考作业·国家开放大学
小二·1 小时前
MyBatis基础入门《十六》企业级插件实战:基于 MyBatis Interceptor 实现 SQL 审计、慢查询监控与数据脱敏
数据库·sql·mybatis
bing.shao1 小时前
Golang WaitGroup 踩坑
开发语言·数据库·golang
专注VB编程开发20年1 小时前
C#内存加载dll和EXE是不是差不多,主要是EXE有入口点
数据库·windows·microsoft·c#
小二·2 小时前
MyBatis基础入门《十二》批量操作优化:高效插入/更新万级数据,告别慢 SQL!
数据库·sql·mybatis
何中应2 小时前
【面试题-6】MySQL
数据库·后端·mysql·面试题
路遥_132 小时前
银河麒麟 V10 安装部署瀚高数据库 HighGoDB 4.5 全流程(统信UOS Server 20同理)
数据库
TDengine (老段)2 小时前
从关系型数据库到时序数据库的思维转变
大数据·数据库·mysql·时序数据库·tdengine·涛思数据·非关系型数据库