原理:数据表的hash分区字段与分析函数中的partition by 字段一致的时候,每个分区上的数据可以单独进行运算,互不干涉。所以可以很快的提高Oracle分析函数的运行效率。具体测试步骤如下:
***步:创建一个分区表和普通表,表结构与DBA_OBJECTS一致:
createtablet_partition_hash(
#p#
第二步:准备数据,从dba_object中把数据插入到两个表。总共插入数据1610880。
insertintot_partition_hashselect*fromdba_objects;
第三步:本采用RANK函数对两个表进行查询。
begin
使用hash分区表总共执行5次的运行时间分别为:46.156s,33.39s,40.516s 34.875s 38.938s.
begin
使用非分区表执行5次的执行时间分别为:141.954s,89.656s,77.906s,98.5s,75.906s.
由此可见采用有效的HASH分区表可以有效提升Oracle分析函数中的执行效率。我相信随着数据量的增加,将会有更明显的效果,回头再测试一个项目中遇到的类似问题。
善用Oracle表空间设计提升数据库性能
优化数据库大幅度提高Oracle分析函数的性能
Oracle设置系统参数进行性能优化
相关文章
标签:Oracle