加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 在Oracle中’Buffer Gets’实际引用了什么?

发布时间:2020-12-12 06:55:49 所属栏目:MsSql教程 来源:网络整理
导读:我正在与Oracle DBA打交道,他已经给我发了一些他已经完成的分析。他的报告中的一个术语是“缓冲获
我正在与Oracle DBA打交道,他已经给我发了一些他已经完成的分析。他的报告中的一个术语是“缓冲获取”,任何想法,这实际上意味着什么?我的猜测是从缓冲区中检索的字节,但我真的不知道。这是一些示例输出:
Buffer Gets    Executions  Gets per Exec  %Total Time (s)  Time (s) Hash Value
--------------- ------------ -------------- ------ -------- --------- ----------
    137,948,100       31,495        4,380.0   98.4  6980.57   6873.46 4212400674
Module: JDBC Thin Client
SELECT fieldOne,fieldTwo,fieldThree,fieldFour,fieldFive FROM TableExample
WHERE fieldOne = 'example'

知道’获得每个执行’意味着什么也是很方便的,因为我猜它们是相关的?我是程序员,但不是DBA。

解决方法

Oracle存储被安排为给定大小的块(例如8k)。表和索引由磁盘上的一系列块组成。当这些块在内存中时,它们占用缓冲区。

当Oracle需要块时,它会执行缓冲区获取。首先,它检查它是否已经具有内存中所需的块。如果是,则使用内存中版本。如果内存中没有块,则它会将其从磁盘读入内存。

因此缓冲区get表示Oracle必须访问块的次数。可以从内存(缓冲区)或导致物理IO满足读取。

由于物理IO非常昂贵(与内存或CPU相比),因此一种调优方法是集中精力减少缓冲区获取,假设这些缓冲区将逐渐减少物理IO。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读