2022年SQL优化根据 .pdf
《2022年SQL优化根据 .pdf》由会员分享,可在线阅读,更多相关《2022年SQL优化根据 .pdf(17页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、我们将简要地介绍以下的Oracle 主题:- 外部调整 :我们应该记住Oracle 并不是单独运行的。因此我们将查看一下通过调整Oracle 服务器以得到高的性能。-Row re-sequencing 以减少磁盘I/O :我们应该懂得Oracle 调优最重要的目标是减少 I/O 。-Oracle SQL 调整。 Oracle SQL 调整是 Oracle 调整中最重要的领域之一,只要通过一些简单的SQL 调优规则就可以大幅度地提升SQL 语句的性能,这是一点都不奇怪的。- 调整 Oracle 排序:排序对于Oracle 性能也是有很大影响的。- 调整 Oracle 的竞争:表和索引的参数设置对
2、于UPDATE 和 INSERT 的性能有很大的影响。我们首先从调整Oracle 外部的环境开始。如果内存和CPU 的资源不足的话,任何的Oracle 调整都是没有帮助的。外部的性能问题Oracle 并不是单独运行的。Oracle 数据库的性能和外部的环境有很大的关系。这些外部的条件包括有: CPU-CPU 资源的不足令查询变慢。当查询超过了Oracle 服务器的CPU 性能时,你的数据库性能就受到CPU 的限制。内存 - 可用于Oralce 的内存数量也会影响SQL 的性能,特别是在数据缓冲和内存排序方面。网络 - 大量的Net8 通信令 SQL 的性能变慢。许多新手都错误的认为应该首先调整
3、Oracle 数据库,而不是先确认外部资源是否足够。实际上,如果外部环境出现瓶颈,再多的Oracle 调整都是没有帮助的。在检查 Oracle 的外部环境时,有两个方面是需要注意的:1 、当运行队列的数目超过服务器的CPU 数量时,服务器的性能就会受到CPU 的限制。补救的方法是为服务器增加额外的CPU 或者关闭需要很多处理资源的组件,例如Oracle Parallel Query 。2 、内存分页。当内存分页时,内存容量已经不足,而内存页是与磁盘上的交换区进行交互的。补救的方法是增加更多的内存,减少Oracle SGA 的大小,或者关闭Oracle 的多线程服务器。可以使用各种标准的服务器工
4、具来得到服务器的统计数据,例如vmstat,glance,top 和sar 。 DBA 的目标是确保数据库服务器拥有足够的CPU 和内存资源来处理Oracle 的请求。以下让我们来看一下Oracle 的 row-resequencing 是如何能够极大地减少磁盘I/O 的。Row-resequencing (行的重新排序)就象我们上面提到的,有经验的Oracle DBA 都知道 I/O 是响应时间的最大组成部分。其中磁盘I/O 特别厉害,因为当Oracle 由磁盘上的一个数据文件得到一个数据块时,读的进程就必须等待物理I/O 操作完成。磁盘操作要比数据缓冲慢10,000 倍。因此,如果可以令
5、I/O 最小化,或者减少由于磁盘上的文件竞争而带来的瓶颈,就可以大大地改善名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 1 页,共 17 页 - - - - - - - - - Oracle 数据库的性能。如果系统响应很慢,通过减少磁盘I/O 就可以有一个很快的改善。如果在一个事务中通过按一定的范围搜索primary-key 索引来访问表,那么重新以CTAS 的方法组织表将是你减少 I/O 的首要策略。通过在物理上将行排序为和primary-key 索引一样的顺序,就可以加快获得数
6、据的速度。就象磁盘的负载平衡一样,行的重新排序也是很简单的,而且也很快。通过与其它的DBA 管理技巧一起使用,就可以在高I/O 的系统中大大地减少响应的时间。在高容量的在线事务处理环境中(online transaction processing , OLTP ),数据是由一个 primary 索引得到的,重新排序表格的行就可以令连续块的顺序和它们的primary 索引一样,这样就可以在索引驱动的表格查询中,减少物理I/O 并且改善响应时间。这个技巧仅在应用选择多行的时候有用,或者在使用索引范围搜索和应用发出多个查询来得到连续的 key 时有效。对于随机的唯一primary-key (主键)的
7、访问将不会由行重新排序中得到好处。让我们看一下它是如何工作的。考虑以下的一个SQL 的查询,它使用一个索引来得到 100 行:selectsalaryfromemployeewherelast_name like B%; 这个查询将会使用last_name_index ,搜索其中的每一行来得到目标行。这个查询将会至少使用 100 次物理磁盘的读取,因为employee 的行存放在不同的数据块中。不过,如果表中的行已经重新排序为和last_name_index 的一样,同样的查询又会怎样处理呢?我们可以看到这个查询只需要三次的磁盘I/O 就读完全部100 个员工的资料(一次用作索引的读取,两次用
8、作数据块的读取),减少了97 次的块读取。重新排序带来的性能改善的程度在于在你开始的时候行的乱序性如何,以及你需要由序列中访问多少行。至于一个表中的行与索引的排序键的匹配程度,可以查看数据字典中的dba_indexes 和 dba_tables 视图得到。在 dba_indexes 的视图中,查看clustering_factor 列。如果clustering_factor 的值和表中的块数目大致一样,那么你的表和索引的顺序是一样的。不过,如果clustering_factor 的值接近表中的行数目,那就表明表格中的行和索引的顺序是不一样的。行重新排序的作用是不可以小看的。在需要进行大范围的索
9、引搜索的大表中,行重新排序可以令查询的性能提高三倍。一旦你已经决定重新排序表中的行,你可以使用以下的工具之一来重新组织表格。. 使用 Oracle 的 Create Table As Select (CTAS) 语法来拷贝表格. Oracle9i 自带的表格重新组织工具以下,我们来看以下SQL 语句的调优。SQL 调优Oracle 的 SQL 调优是一个复杂的主题,甚至是需要整本书来介绍Oracle SQL 调优的细微差别。不过有一些基本的规则是每个Oracle DBA 都需要跟从的,这些规则可以改善他们系统的性能。SQL 调优的目标是简单的:. 消除不必要的大表全表搜索:不必要的全表搜索导致
10、大量不必要的I/O ,从而拖慢整个数据库的性能。调优专家首先会根据查询返回的行数目来评价SQL 。在一个有序的表中,如果查询返回少于40% 的行,或者在一个无序的表中,返回少于7% 的行,那么这个查询都可以调整为使用一个索引来代替全表搜索。对于不必要的全表搜索来说,最常见的调优方法是增加索引。可以在表中加入标准的B 树索引,也可以加入bitmap 和基于函数的索引。要决定是否消除一个全表搜索,你可以仔细检查索引搜索的I/O 开销和全表搜索的开销,它们的开销和数据块的读取和可能的并行执行有关,并将两者作对比。在一些情况名师资料总结 - - -精品资料欢迎下载 - - - - - - - - -
11、- - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 17 页 - - - - - - - - - 下,一些不必要的全表搜索的消除可以通过强制使用一个index 来达到,只需要在SQL 语句中加入一个索引的提示就可以了。. 在全表搜索是一个最快的访问方法时,将小表的全表搜索放到缓存中,调优专家应该确保有一个专门的数据缓冲用作行缓冲。在Oracle7 中,你可以使用alter table xxx cache 语句,在Oracle8 或以上,小表可以被强制为放到KEEP 池中缓冲。. 确保最优的索引使用:对于改善查询的速度,这是特别重要的。有时Oracle
12、可以选择多个索引来进行查询,调优专家必须检查每个索引并且确保Oracle 使用正确的索引。它还包括 bitmap 和基于函数的索引的使用。. 确保最优的JOIN 操作:有些查询使用NESTED LOOP join 快一些,有些则是HASH join 快一些,另外一些则是sort-merge join 更快。这些规则看来简单,不过它们占SQL 调优任务的90% ,并且它们也无需完全懂得Oracle SQL 的内部运作。以下我们来简单概览以下Oracle SQL 的优化。减少排序我们首先简要查看Oracle 的排序,并且看一看排序操作是如何影响性能的。调整Oracle 的排序操作排序是 SQL 语
13、法中一个小的方面,但很重要,在Oracle 的调整中,它常常被忽略。当使用 create index 、 ORDER BY 或者 GROUP BY 的语句时,Oracle 数据库将会自动执行排序的操作。通常,在以下的情况下Oracle 会进行排序的操作:使用 Order by 的 SQL 语句使用 Group by 的 SQL 语句在创建索引的时候distinct minus union 进行 table join 时,由于现有索引的不足而导致SQL 优化器调用MERGE SORT 当与 Oracle 建立起一个session 时,在内存中就会为该session 分配一个私有的排序区域。如果该
14、连接是一个专用的连接(dedicated connection) ,那么就会根据init.ora 中sort_area_size 参数的大小在内存中分配一个Program Global Area (PGA) 。如果连接是通过多线程服务器建立的,那么排序的空间就在large_pool 中分配。不幸的是,对于所有的session ,用做排序的内存量都必须是一样的,我们不能为需要更大排序的操作分配额外的排序区域。因此,设计者必须作出一个平衡,在分配足够的排序区域以避免发生大的排序任务时出现磁盘排序(disk sorts )的同时,对于那些并不需要进行很大排序的任务,就会出现一些浪费。当然,当排序的空
15、间需求超出了sort_area_size 的大小时,这时将会在TEMP 表空间中分页进行磁盘排序。磁盘排序要比内存排序大概慢14,000 倍。上面我们已经提到,私有排序区域的大小是有init.ora 中的 sort_area_size 参数决定的。每个排序所占用的大小由init.ora 中的 sort_area_retained_size 参数决定。当排序不能在分配的空间中完成时,就会使用磁盘排序的方式,即在Oracle 实例中的临时表空间中进行。磁盘排序的开销是很大的,有几个方面的原因。首先,和内存排序相比较,它们特别慢;而且磁盘排序会消耗临时表空间中的资源。Oracle 还必须分配缓冲池块
16、来保持临时表空间中的块。无论什么时候,内存排序都比磁盘排序好,磁盘排序将会令任务变慢,并且会影响 Oracle 实例的当前任务的执行。还有,过多的磁盘排序将会令free buffer waits 的值变高,从而令其它任务的数据块由缓冲中移走。接着,让我们看一下Oracle 的竞争,并且看一下表的存储参数的设置是如何影响SQL UPDATE 和 INSERT 语句的性能的。名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 3 页,共 17 页 - - - - - - - - - 调整Or
17、acle 的竞争Oracle 的其中一个优点时它可以管理每个表空间中的自由空间。Oracle 负责处理表和索引的空间管理,这样就可以让我们无需懂得Oracle 的表和索引的内部运作。不过,对于有经验的Oracle 调优专家来说,他需要懂得Oracle 是如何管理表的extent 和空闲的数据块。对于调整拥有高的insert 或者 update 的系统来说,这是非常重要的。要精通对象的调整,你需要懂得freelists 和 freelist 组的行为,它们和pctfree 及pctused 参数的值有关。这些知识对于企业资源计划(ERP )的应用是特别重要的,因为在这些应用中,不正确的表设置通常
18、是DML 语句执行慢的原因。对于初学者来说,最常见的错误是认为默认的Oracle 参数对于所有的对象都是最佳的。除非磁盘的消耗不是一个问题,否则在设置表的pctfree 和 pctused 参数时,就必须考虑平均的行长和数据库的块大小,这样空的块才会被有效地放到freelists 中。当这些设置不正确时,那些得到的freelists 也是 dead 块,因为它们没有足够的空间来存储一行,这样将会导致明显的处理延迟。Freelists 对于有效地重新使用Oracle 表空间中的空间是很重要的,它和pctfree 及 pctused 这两个存储参数的设置直接相关。通过将pctused 设置为一个高
19、的值,这时数据库就会尽快地重新使用块。不过,高性能和有效地重新使用表的块是对立的。在调整Oracle 的表格和索引时,需要认真考虑究竟需要高性能还是有效的空间重用,并且据此来设置表的参数。以下我们来看一下这些freelists 是如何影响Oracle 的性能的。当有一个请求需要插入一行到表格中时,Oracle 就会到 freelist 中寻找一个有足够的空间来容纳一行的块。你也许知道,freelist 串是放在表格或者索引的第一个块中,这个块也被称为段头(segment header )。 pctfree 和 pctused 参数的唯一目的就是为了控制块如何在 freelists 中进出。虽然
20、freelist link 和 unlink 是简单的Oracle 功能,不过设置freelist link (pctused) 和 unlink (pctfree) 对 Oracle 的性能确实有影响。由 DBA 的基本知识知道,pctfree 参数是控制freelist un-links 的(即将块由freelists 中移除)。设置pctfree=10 意味着每个块都保留10% 的空间用作行扩展。pctused 参数是控制freelist re-links 的。设置pctused=40 意味着只有在块的使用低于40% 时才会回到表格的freelists 中。许多新手对于一个块重新回到fr
21、eelists 后的处理都有些误解。其实,一旦由于一个删除的操作而令块被重新加入到freelist 中,它将会一直保留在freelist 中即使空间的使用超过了 60% ,只有在到达pctfree 时才会将数据块由freelist 中移走。表格和索引存储参数设置的要求总结以下的一些规则是用来设置freelists, freelist groups, pctfree 和 pctused 存储参数的。你也知道,pctused 和 pctfree 的值是可以很容易地通过alter table 命令修改的,一个好的DBA 应该知道如何设置这些参数的最佳值。有效地使用空间和高性能之间是有矛盾的,而表格的
22、存储参数就是控制这个方面的矛盾:. 对于需要有效地重新使用空间,可以设置一个高的pctused 值,不过副作用是需要额外的I/O 。一个高的pctused 值意味着相对满的块都会放到freelist 中。因此,这些块在再次满之前只可以接受几行记录,从而导致更多的I/O 。. 追求高性能的话,可以将pctused 设置为一个低的值,这意味着Oracle 不会将数据块放到 freelists 中直到它几乎是空的。那么块将可以在满之前接收更多的行,因此可以减少插入操作的I/O 。要记住Oracle 扩展新块的性能要比重新使用现有的块高。对于Oracle 来说,扩展一个表比管理freelists 消耗
23、更少的资源。让我们来回顾一下设置对象存储参数的一些常见规则:经常将pctused 设置为可以接收一条新行。对于不能接受一行的free blocks 对于我名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 4 页,共 17 页 - - - - - - - - - 们来说是没有用的。如果这样做,将会令Oracle 的性能变慢,因为Oracle 将在扩展表来得到一个空的块之前,企图读取5 个 dead 的 free block 。表格中chained rows 的出现意味着pctfree 太
24、低或者是db_block_size 太少。在很多情况下,RAW 和 LONG RAW 列都很巨大,以至超过了Oracle 的最大块的大小,这时 chained rows 是不可以避免的。如果一个表有同时插入的SQL 语句,那么它需要有同时删除的语句。运行单一个一个清除的工作将会把全部的空闲块放到一个freelist 中,而没有其它包含有任何空闲块的freelists 出现。 freelist 参数应该设置为表格同时更新的最大值。例如,如果在任何时候,某个表最多有 20 个用户执行插入的操作,那么该表的参数应该设置为freelists=20 。应记住的是freelist groups 参数的值只
25、是对于Oracle Parallel Server 和 Real Application Clusters 才是有用的。对于这类Oracle , freelist groups 应该设置为访问该表格的 Oracle Parallel Server 实例的数目。索引详解什么是索引索引是建立在表的一列或多个列上的辅助对象,目的是加快访问表中的数据;Oracle 存储索引的数据结构是B*树,位图索引也是如此,只不过是叶子节点不同B*数索引;索引由根节点、分支节点和叶子节点组成,上级索引块包含下级索引块的索引数据,叶节点包含索引数据和确定行实际位置的rowid。使用索引的目的加快查询速度减少 I/O
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年SQL优化根据 2022 SQL 优化 根据
限制150内