1、制作测试表

create table t1 as select * from FW_T_GTXLOG

insert into t1 select * from t1;

create table t2 compress as select * from t1

create table t3 as select * from t1

2、查看测试表数据量

select count(*) from t1;

select count(*) from t2;

select count(*) from t3;

3、查看测试表物理大小

SQL> select t.bytes/1024/1024/1024,t.blocks from dba_segments t where t.segment_name='T1';

T.BYTES/1024/1024/1024    BLOCKS

---------------------- ----------

16.8876953G   2213504

Elapsed: 00:00:00.14

SQL> select t.bytes/1024/1024/1024,t.blocks from dba_segments t where t.segment_name='T2';

T.BYTES/1024/1024/1024    BLOCKS

---------------------- ----------

13.0625G   1712128

Elapsed: 00:00:00.10

SQL> select t.bytes/1024/1024/1024,t.blocks from dba_segments t where t.segment_name='T3';

T.BYTES/1024/1024/1024    BLOCKS

---------------------- ----------

16.8359375G   2206720

Elapsed: 00:00:00.09

4、查看测试表索引大小

SQL> select t.bytes/1024/1024/1024,t.blocks*8192 from dba_segments t where t.segment_name='IND_GUID_1';

T.BYTES/1024/1024/1024 T.BLOCKS*8192

---------------------- -------------

3.125   3355443200

Elapsed: 00:00:00.10

SQL> select t.bytes/1024/1024/1024,t.blocks*8192 from dba_segments t where t.segment_name='IND_GUID_2';

T.BYTES/1024/1024/1024 T.BLOCKS*8192

---------------------- -------------

.5390625    578813952

Elapsed: 00:00:00.09

SQL> select t.bytes/1024/1024/1024,t.blocks*8192 from dba_segments t where t.segment_name='IND_GUID_3';

T.BYTES/1024/1024/1024 T.BLOCKS*8192

---------------------- -------------

.5390625    578813952

Elapsed: 00:00:00.10

5、查看测试表定义语句

-- Create table T1

create table T1

(

GUID NVARCHAR2(32) not null,

GTXID     NVARCHAR2(200),

STARTTIME NVARCHAR2(32),

SOURCETX  NUMBER(1),

STATUS    NUMBER(1),

ENDTIME   NVARCHAR2(32),

DOMAIN    NVARCHAR2(50)

)

tablespace EFMIS

pctfree 10

initrans 1

maxtrans 255

storage

(

initial 64

next 8

minextents 1

maxextents unlimited

);

-- Create/Recreate indexes

create index IND_GUID_1 on T1 (GUID)

tablespace EFMIS

pctfree 10

initrans 2

maxtrans 255

storage

(

initial 64K

next 1M

minextents 1

maxextents unlimited

);

-- Create table T2

create table T2

(

GUID NVARCHAR2(32) not null,

GTXID     NVARCHAR2(200),

STARTTIME NVARCHAR2(32),

SOURCETX  NUMBER(1),

STATUS    NUMBER(1),

ENDTIME   NVARCHAR2(32),

DOMAIN    NVARCHAR2(50)

)

tablespace EFMIS

pctfree 0

initrans 1

maxtrans 255

storage

(

initial 64

next 8

minextents 1

maxextents unlimited

)

compress;  -------------------------------------------------------------------------------

-- Create/Recreate indexes

create index IND_GUID_2 on T2 (GUID)

tablespace EFMIS

pctfree 10

initrans 2

maxtrans 255

storage

(

initial 64K

next 1M

minextents 1

maxextents unlimited

)

compress; ---------------------------------------------------

-- Create table T3

create table T3

(

GUID NVARCHAR2(32) not null,

GTXID     NVARCHAR2(200),

STARTTIME NVARCHAR2(32),

SOURCETX  NUMBER(1),

STATUS    NUMBER(1),

ENDTIME   NVARCHAR2(32),

DOMAIN    NVARCHAR2(50)

)

tablespace EFMIS

pctfree 10

initrans 1

maxtrans 255

storage

(

initial 64

next 8

minextents 1

maxextents unlimited

);

-- Create/Recreate indexes

create index IND_GUID_3 on T3 (GUID)

tablespace EFMIS

pctfree 10

initrans 2

maxtrans 255

storage

(

initial 64K

next 1M

minextents 1

maxextents unlimited

)

compress;    ---------------------------------------------------------------------

6、收集3张表统计信息

begin

dbms_stats.gather_table_stats(ownname          => 'FASP_62',

tabname          => 'T1',

estimate_percent => 30,

method_opt       => 'FOR ALL COLUMNS SIZE 10',

degree => 4,

cascade => TRUE);

END;

7、测试具体查询语句效率:table access full

SQL> select count(*) from t1;

COUNT(*)

----------

37458112

Elapsed: 00:00:31.22

SQL> select count(*) from t2;

COUNT(*)

----------

37458112

Elapsed: 00:00:08.66

SQL> select count(*) from t3;

COUNT(*)

----------

37458112

Elapsed: 00:00:08.25

8、测试具体查询语句效率:index fasp full scan

SQL> select count(guid) from t1 where guid like '%BA92A682D9%';

COUNT(GUID)

-----------

32

Elapsed: 00:00:34.52

SQL> select count(guid) from t2 where guid like '%BA92A682D9%';

COUNT(GUID)

-----------

32

Elapsed: 00:00:18.27

SQL> select count(guid) from t3 where guid like '%BA92A682D9%';

COUNT(GUID)

-----------

32

Elapsed: 00:00:20.27

结论:t2\t3表的索引为压缩索引,从以上执行结果可知,索引重复率情况下,compress压缩对于select而言,具有一定的效果,提高速度一半以上。

9、结论

1、非唯一性索引可以建立compress索引。

create index IND_GUID_3 on T3 (GUID) tablespace EFMIS  compress;

2、可以通过以下命令查看索引或者表占据的硬盘容量:

select t.bytes/1024/1024/1024,t.blocks*8192 from dba_segments t where t.segment_name='IND_GUID_3';

select t.bytes/1024/1024/1024,t.blocks*8192 from dba_segments t where t.segment_name='IND_GUID_1';

以上sql查询出的索引大小与为压缩的索引大小相差悬殊,择证明压缩后可以提高查询效率。

Oracle性能优化之表压缩及并行提高效率的测试的更多相关文章

  1. Oracle性能优化顺序表名称来选择最有效的学习笔记

    选择最有效的顺序表名(只有有效的基于规则的优化)  ORACLE分析器按照订单处理从右到左FROM在FROM子句中的表名,故FROM写在最后的表(基础表 driving table)将被最先处理. 在 ...

  2. oracle性能优化之表设计

    数据库优化的目标无非是避免磁盘I/O瓶颈.减少CPU利用率和减少资源竞争.为了便于读者阅读和理解,笔者参阅了Sybase.Informix和Oracle等大型数据库系统参考资料,基于多年的工程实践经验 ...

  3. oracle性能优化之awr分析

    oracle性能优化之awr分析 作者:bingjava 最近某证券公司系统在业务期间系统运行缓慢,初步排查怀疑是数据库存在性能问题,因此导出了oracle的awr报告进行分析,在此进行记录. 导致系 ...

  4. 【转载】我眼中的Oracle性能优化

    我眼中的Oracle性能优化 大家对于一个业务系统的运行关心有如下几个方面:功能性.稳定性.效率.安全性.而一个系统的性能有包含了网络性能.应用性能.中间件性能.数据库性能等等. 今天从数据库性能的角 ...

  5. SQL Server查询性能优化——堆表、碎片与索引(二)

    本文是对 SQL Server查询性能优化——堆表.碎片与索引(一)的一些总结.  第一:先对 SQL Server查询性能优化——堆表.碎片与索引(一)中的例一的SET STATISTICS IO之 ...

  6. 我眼中的 Oracle 性能优化

    恒生技术之眼 作者 林景忠 大家对于一个业务系统的运行关心有如下几个方面:功能性.稳定性.效率.安全性.而一个系统的性能有包含了网络性能.应用性能.中间件性能.数据库性能等等. 今天从数据库性能的角度 ...

  7. Oracle性能优化1-总体思路和误区

    最近在看梁敬彬老师关于Oracle性能优化的一些案例,在这里做一些简单的总结 1.COUNT(*)与COUNT(列)哪个更快 drop table t purge; create table t as ...

  8. 0709MySQL 数据库性能优化之表结构优化

    转自http://isky000.com/database/mysql-perfornamce-tuning-schema MySQL 数据库性能优化之缓存参数优化 MySQL数据库性能优化之硬件瓶颈 ...

  9. Oracle 性能优化的基本方法

    Oracle 性能优化的基本方法概述 1)设立合理的性能优化目标. 2)测量并记录当前性能. 3)确定当前Oracle性能瓶颈(Oracle等待什么.哪些SQL语句是该等待事件的成分). 4)把等待事 ...

随机推荐

  1. js 补零方法,如果不足位数

    var pad = function() { var tbl = []; return function(num, n) { var len = n-num.toString().length; if ...

  2. 【Java 线程的深入研究3】最简单实例说明wait、notify、notifyAll的使用方法

    wait().notify().notifyAll()是三个定义在Object类里的方法,可以用来控制线程的状态. 这三个方法最终调用的都是jvm级的native方法.随着jvm运行平台的不同可能有些 ...

  3. write solid code Chapter 2 练习题4 的解答与扩展

    原题: 4.When programmers add new elements to an enumeration, they sometimes forget to add new cases to ...

  4. Golang 语言安装

    Ubuntu: 从源代码编译安装 安装gcc工具,因为golang有些功能是使用c写的,所以构建golang的编译是必须的 apt-get install bison gawk gcc libc6-d ...

  5. Makefile--基本规则(零)

    [版权声明:转载请保留出处:周学伟:http://www.cnblogs.com/zxouxuewei/] 一般一个稍大的linux项目会有很多个源文件组成,最终的可执行程序也是由这许多个源文件编译链 ...

  6. JBPM4.4_jBPM4.4的流程定义语言(设计流程)

    1. jBPM4.4的流程定义语言(设计流程) 1.1. process(流程) 是.jpdl.xml的根元素,可以指定的属性有: 属性名 作用说明 name 流程定义的名称,用于显示. key 流程 ...

  7. python计算时间差的方法

    本文实例讲述了python计算时间差的方法.分享给大家供大家参考.具体分析如下: 1.问题: 给定你两个日期,如何计算这两个日期之间间隔几天,几个星期,几个月,几年? 2.解决方法: 标准模块date ...

  8. list中的比较

    一说到list的的确不知道写些什么.....我觉得别人总结的比我写的还要好很多. 我擅长记录自己的误区. |--List:元素是有序的(怎么存的就怎么取出来,顺序不会乱),元素可以重复(角标1上有个3 ...

  9. View的setTag()与getTag()方法使用

    通常我们是用findViewById()方法来取得我们要使用的View控件,不过除了这一种方法之处 ,我们还可以用View中的setTag(Onbect)给View添加一个格外的数据,再用getTag ...

  10. iOS设计模式之类族(class cluster)

    类族模式在UIKit(user interface framework)使用的范围已经远远超过我们的想象,比如,UIButton,NSArray,NSString,NSNumber等, 例如NSNum ...