龙盟编程博客 | 无障碍搜索 | 云盘搜索神器
快速搜索
主页 > 数据库类 > Oracle 技术 >

如何使用Hash分区优化Oracle分析函数(1)(2)

时间:2011-04-12 23:18来源:未知 作者:admin 点击:
分享到:
第二步:准备数据,从dba_object中把数据插入到两个表。总共插入数据1610880。 insertintot_partition_hashselect*fromdba_objects; insertintot_partition_hashselect*fromdba_objects

第二步:准备数据,从dba_object中把数据插入到两个表。总共插入数据1610880。

  1. insert into t_partition_hash select * from dba_objects;  
  2. insert into t_partition_hash select * from dba_objects;  
  3.  

第三步:本采用RANK函数对两个表进行查询。

  1. begin  
  2. insert into t_rank  
  3. select object_id,  
  4. rank() over (partition by object_type order by object_id) r_object_id,  
  5. rank() over (partition by object_type order by subobject_name) r_subobject_name ,  
  6. rank() over (partition by object_type order by created) r_created,  
  7. rank() over (partition by object_type order by last_ddl_time) r_last_ddl_time ,  
  8. rank() over (partition by object_type order by status) r_object_type  
  9. from t_partition_hash;  
  10. end;  
  11.  

使用hash分区表总共执行5次的运行时间分别为:46.156s,33.39s,40.516s 34.875s 38.938s.

  1. begin  
  2. insert into t_rank  
  3. select object_id,  
  4. rank() over (partition by object_type order by object_id) r_object_id,  
  5. rank() over (partition by object_type order by subobject_name) r_subobject_name ,  
  6. rank() over (partition by object_type order by created) r_created,  
  7. rank() over (partition by object_type order by last_ddl_time) r_last_ddl_time ,  
  8. rank() over (partition by object_type order by status) r_object_type  
  9. from t_big_table;  
  10. end;  
  11.  

使用非分区表执行5次的执行时间分别为:141.954s,89.656s,77.906s,98.5s,75.906s.

由此可见采用有效的HASH分区表可以有效提升Oracle分析函数中的执行效率。我相信随着数据量的增加,将会有更明显的效果,回头再测试一个项目中遇到的类似问题。

善用Oracle表空间设计提升数据库性能

优化数据库大幅度提高Oracle分析函数的性能

Oracle设置系统参数进行性能优化

  1. 修改Oracle存储过程所需代码
  2. 对Oracle存储过程的总结
  3. 实现Oracle存储过程的实际应用的代码 
  4. 深入高性能的Oracle动态SQL开发 
  5. Oracle SQL的优化规则解析 
精彩图集

赞助商链接