当前位置: > 数据库 > Oracle >

Oracle内存结构研究-PGA篇(2)

时间:2015-07-12 16:11来源:linux.it.net.cn 作者:IT



六、操作命令
系统级更改:
ALTER SYSTEM SET WORKAREA_SIZE_POLICY = {AUTO | MANAUL};
ALTER SYSTEM SET PGA_AGGREGATE_TARGET=100000000;
ALTER SYSTEM SET SORT_AREA_SIZE = 65536 SCOPE = SPFILE;
ALTER SYSTEM SET HASH_AREA_SIZE = 65536 SCOPE = SPFILE;

会话级更改
ALTER SESSION SET WORKAREA_SIZE_POLICY = {AUTO | MANAUL};
ALTER SESSION SET SORT_AREA_SIZE = 65536;
ALTER SESSION SET HASH_AREA_SIZE = 65536;


七、学以致用
1,排序区:
pga_aggregate_target为100MB,单个查询能用到5%也就是5MB时排序所需时间

SQL> create table sorttable as select * from all_objects;

表已创建。

SQL> insert into sorttable (select * from sorttable);

已创建49735行。

SQL> insert into sorttable (select * from sorttable);

已创建99470行。

SQL> set timing on;
SQL> set autotrace traceonly;
SQL> select * from sorttable order by object_id;

已选择198940行。

已用时间:  00: 00: 50.49

Session级修改排序区为30mb所需时间
SQL> ALTER SESSION SET WORKAREA_SIZE_POLICY = MANUAL;

会话已更改。

已用时间:  00: 00: 00.02
SQL> ALTER SESSION SET SORT_AREA_SIZE = 30000000;

会话已更改。

已用时间:  00: 00: 00.01
SQL> select * from sorttable order by object_id;

已选择198940行。

已用时间:  00: 00: 10.76

可以看到所需时间从50.49秒减少到10.31秒,速度提升很明显。

2,散列区:
pga_aggregate_target为100MB,单个查询能用到5%也就是5MB时表连接所需时间

SQL> select /*+ use_hash(tb1 tb2)*/ * from sorttable tb1,sorttable tb2 where tb1.object_id=tb2.object_id;

已选择49735行。

已用时间:  00: 00: 40.50

Session级修改散列区为30mb所需时间
SQL> ALTER SESSION SET WORKAREA_SIZE_POLICY = MANUAL;

会话已更改。

已用时间:  00: 00: 00.01
SQL> ALTER SESSION SET HASH_AREA_SIZE = 30000000;

会话已更改。

已用时间:  00: 00: 00.01
SQL> select /*+ use_hash(tb1 tb2)*/ * from sorttable tb1,sorttable tb2 where tb1.object_id=tb2.object_id;

已选择49735行。

已用时间:  00: 00: 04.47

所需时间由40.50秒提升到4.47秒,效果同样很明显。

备注:以上实验皆执行全表扫描保证相关表读入缓冲区中,避免因数据没读入缓存造成误差。


结论:在9iR2版以后,PGA不再像以前那样困扰DBA了,Oracle会帮我们做好PGA的分配。但这并不意味着DBA不需要深入了解PGA了,掌握PGA并根据适当应用会让工作如虎添翼。
(责任编辑:IT)
------分隔线----------------------------