通过持续的调优工作和监测可以找到运行中应用程序的最佳值。此时,UNIX内核的内存不易减少,需要有效地调优数据库内存区域,使用更少内存发挥相同水平的性能。如果内核内存使用约100 MB,并发用户为30名,每个Oracle进程的内存为 10 MB,假定 sort_area_size为 1MB,按以下公式计算出430 MB。100 MB+30×=430 MB因此,物理内存为1 GB的系统,可分配大约600 MB的SGA使用。......
2023-11-01
1)例子(一)
正确使用SQL的例子(一)如图5-12所示。
图5-12 正确使用SQL的例子(一)
(1)问题:在上述SQL中,ORDD是唯一性较好的列。因此B.ORDD = : TrDay或B.ORDD = : WorkDay的扫描范围较窄,使用索引时响应速度非常快。但当上述SQL中B.ORDD, B.RSV ORD_DVCD的值等于‘02’时应与:TrDay比较,否则应与:WorkDay比较。因此创建的条件公式为 B.ORDD=DECODE(B.RSV_ORD_DVCD,'02',:TrDay, :WorkDay)。但条件公式的两边是列时优化器会判断无法使用索引。此时上述条件与输入值无关,会对表进行全范围扫描,因此响应速度较慢。
(2)解决方案:可通过OR将以上条件分为两个条件。在这种情况下,优化器使用OR从内部分为两个SQL语句并各自使用索引,再将执行结果合并(CONCATENATION)为一个结果。
2)例子(二 )(www.chuimin.cn)
正确使用SQL的例子如图5-13所示。
图5-13 正确使用SQL的例子(二)
(1)问题:连接的两个表的条件中决定扫描范围的条件是"AND SUBSTR (A.AC_NO, 1, 3)LIKE : IN_org_cd AND SUBSTR (A.ac_ no, 4, 6) < 600000"。但因对列使用函数所以无法应用索引,即便条件的扫描范围较窄也无法改善响应速度(AC_NO由11位字符构成,后面8位字符保存为数字值)。
(2)解决方案:条件子句AND SUBSTR (A.ac_no,4,6) <'600000'解析后与BETWEEN'000001'| |' 00'和599999'| |' 99'相同。因此可按以下方法变更条件公式并使用相应索引。
有关数据库性能管理与调优的文章
通过持续的调优工作和监测可以找到运行中应用程序的最佳值。此时,UNIX内核的内存不易减少,需要有效地调优数据库内存区域,使用更少内存发挥相同水平的性能。如果内核内存使用约100 MB,并发用户为30名,每个Oracle进程的内存为 10 MB,假定 sort_area_size为 1MB,按以下公式计算出430 MB。100 MB+30×=430 MB因此,物理内存为1 GB的系统,可分配大约600 MB的SGA使用。......
2023-11-01
而重中之重仍然是调优访问数据库SQL语句的方法,因为很少能像SQL调优这样可以在短时间内以低成本得到效果。因此,为了性能考虑,开发者应不遗余力地投入时间和精力进行SQL调优。如果对未优化的SQL进行调优,则计划增设容量的许多企业都无须执行容量增设。大量数据排序的SQL或者大量访问数据块的未优化的SQL,可能会过量地使用内存。就因为这种现象,才会因未优化的SQL而出现磁盘I/O增加的情况。SQL的优化过程必然也涉及索引的优化。......
2023-11-01
为根据不同情况使用适当的索引,要学习各种类型的索引。因为只有明确了解表和索引的概念才能轻松解决复杂的内容。创建索引抽屉时,应考虑偶有发生的损益分歧点,考虑是否创建。总体来说,索引是用户使用SQL语句查找时为提高查找速度而创建的对象。但若创建太多索引,购买新书或废弃时,会产生额外的维护费用。这是由于添加或删除书籍时应更新现有的索引抽屉。......
2023-11-01
图5-5部分范围处理使用例子(二)以下是从两个表中分别提取生日和工资的SQL语句。为删除重复数据使用了UNION,因此无法执行部分范围处理。图5-6部分范围处理使用例子(三)按特定表的列顺序排序并显示多个表的连接结果时,如果要使用部分范围处理,可从以下两个方法中选择一个使用:在In-line view中对要排序的表进行 ORDER BY并用作 driving table以执行NESTED LOOP JOIN。......
2023-11-01
HASH JOIN是突出SORT MERGE JOIN优点并弥补其缺点的连接方法。该连接是对连接的对象表应用 HASH函数进行合并的方法。其特征是不仅只使用 HASH JOIN,而且提供通过并行处理大容量数据的最佳解决方案。但不建议在OLTP等状况下使用,因为HASH JOIN已为大容量处理进行优化,会占用大量系统资源。不会受JOIN条件(链路)索引有无的影响。2)使用标准由于链路使用HASH Key,因此仅用于EQUI-JOIN。在执行计划中成为HASHING对象的表始终在最前面,但如果是OUTER JOIN则完全相反。......
2023-11-01
SORT MERGE JOIN指各自访问两侧表的处理范围后逐一扫描排序结果,同时使用连接条件进行合并的方式。通过SORT MERGE JOIN引导调优的情况几乎不存在,但可能对减少RANDOM ACCESS、大容量处理对象集有效。以下将介绍SORT MERGE JOIN的其他特征以及能保证良好性能的情形。通常NESTED LOOP JOIN对待处理数据量较少的在线应用程序更为有效,因此请勿随意使用SORT MERGE JOIN。......
2023-11-01
实例已启动意味着数据库系统运行所需的后台进程已启动,并且处于“确保内存可用于数据处理”的状态,这种实例的调优将成为DBMS性能调优的重要基础。1) DBMS 内存 区域——SGASGA 是作为实例启动时确保控制器信息保存和数据处理空间的内存区域,存在于实例访问的所有进程共享的内存区域中。SGA相关调优的基准基本以命中率评价为主,通过适当地调整相关参数,将实际运行反映到评价结果中。......
2023-11-01
对象表的连接顺序和方法不同是为了加快访问速度。因此即使变更连接方法和顺序,结果值也不能有任何变化。连接时表的驱动顺序是性能中的重要组成部分。4)优化器的连接选择对于参与连接条件语句的列,索引位置对优化器决定执行计划时的连接顺序和方法有很大影响。连接列的两侧均无索引时,将SORT MERGE JOIN或HASH JOIN用作连接方法。......
2023-11-01
相关推荐