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)
六、操作命令 系统级更改: 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) |