共计 2883 个字符,预计需要花费 8 分钟才能阅读完成。
这篇文章给大家分享的是有关 oracle 如何实现压缩表的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考,一起跟随丸趣 TV 小编过来看看吧。
表压缩是如何工作的
在 Orcle9i 第 2 版中,表压缩特性通过删除在数据库表中发现的重复数据值来节省空间。压缩是在数据库的数据块级别上进行的。当确定一个表要被压缩后,数据库便在每一个数据库数据块中保留空间,以便储存在该数据块中的多个位置上出现的数据的单一拷贝。这一被保留的空间被称作符号表(symbol table)。被标识为要进行压缩的数据只存储在该符号表中,而不是在数据库行本身内。当在一个数据库行中出现被标识为要压缩的数据时,该行在该符号表中存储一个指向相关数据的指针,而不是数据本身。节约空间是通过删除表中数据值的冗余拷贝而实现的。
对于用户或应用程序开发人员来说,表压缩的效果是透明的。无论表是否被压缩,开发人员访问表的方式都是相同的,所以当你决定压缩一个表时,不需要修改 SQL 查询。表压缩的设置通常由数据库管理人员或设计人员进行配置,几乎不需要开发人员或用户参与。
1. 表级别:
1.1 创建一个压缩表:
创建表时使用 COMPRESS 关键字,COMPRESS 关键字指示 Oracle 数据库尽可能以压缩的格式存储该表中的行。
SQL create table tmp_test
(id number,phone varchar2(20),create_time date)
compress;
1.2 修改现有表为压缩表:
SQL alter table tmp_test compress;
取消表的压缩:
SQL alter table tmp_test nocompress;
1.3 确定表是否被压缩:
确定一个表是否使用了压缩, 查询 user_tables,compression 字段表明表是否被压缩.
SQL select table_name,compression from user_tables where table_name not like BIN%
TABLE_NAME COMPRESS
—————————— ——–
CLASSES ENABLED
ROOMS ENABLED
STUDENTS DISABLED
MAJOR_STATS DISABLED
2. 表空间级别:
2.1 创建表压缩空间:
可以在表空间级别上定义 COMPRESS 属性,既可以在生成时利用 CREATE TABLESPACE 来定义,也可以稍后时间利用 ALTER TABLESPACE 来定义。
与其他存储参数类似,COMPRESS 属性也具有一些继承特性。当在一个表空间中创建一个表时,它从该表空间继承 COMPRESS 属性。
可以在一个表空间直接压缩或解压缩一个表,而不用考虑表空间级别上的 COMPRESS 属性。
2.2 使现有表空间转换为压缩表空间 SQL alter tablespace sms default compress;
SQL alter tablespace sms default nocompress;
2.3 确定是否已经利用 COMPRESS 对一个表空间进行了定义,可查询 USER_TABLESPACES 数据字典视图并查看 DEF_TAB_COMPRESSION 列
SQL select tablespace_name,def_tab_compression from user_tablespaces;
TABLESPACE DEF_TAB_
———- ——–
USERS DISABLED
TEST DISABLED
UNDOTBS01 DISABLED
STATPACK DISABLED
3. 向一个压缩的表中加载数据
注: 当像上面那样指定 compress 时, 其它表中 (表空间) 的数据并没有压缩, 它只是修改了数据字典的设置; 只有在向一个表中加裁 / 插入数据时, 才会压缩数据.
只有在使用下面 4 种方法时, 表中的数据才会被压缩存放:
直接路径的 sql*load
带有 /*+ append*/ 的 insert 语句
create table .. as select..
并行 insert
4. 压缩一个已经存在但并未压缩的表
使用 alter table .. move compress 使一个已存在但未压缩的表转换为压缩表.
SQL alter table tmp_test move compress;
同样, 也可以使用 alter table.. move nocompress 来解压一个已经压缩的表:
SQL alter table tmp_test move nocompress;
5. 压缩一个物化视图
使用用于压缩表的类似方式来压缩物化视图。
基于多个表的联接生成的物化视图通常很适于压缩,因为它们通常拥有大量的重复数据项。
SQL create materialized view mv_tmp_test
compress
as
select a.phone,b.create_time from tmp_test a,recv_stat b
where a.id=b.id;
可以使用 ALTER MATERIALIZED VIEW 命令来改变一个物化视图的压缩属性。
当你使用此命令时,请注意通常是在下一次刷新该物化视图时才会进行实际的压缩。
SQL alter materialized view mv_temp_test compress;
6. 压缩一个已分区的表
在对已分区的表应用压缩时,可以有很多种选择。你可以在表级别上应用压缩,也可以在分区级别上应用压缩。
你可以利用 ALTER TABLE …MOVE PARTITION 命令对此分区进行压缩
SQL alter table tmp_test move partition create_200606 compress;
要找出一个表中的哪些分区被压缩了,可以查询数据字典视图 USER_TAB_PARTITIONS
SQL SELECT TABLE_NAME, PARTITION_NAME,COMPRESSION FROM USER_TAB_PARTITIONS;
7. 压缩表的性能开销
一个压缩的表可以存储在更少的数据块中,从而节省了储存空间,而使用更少的数据块也意味着性能的提高。 在一个 I / O 受到一定限制的环境中对一个压缩的表进行查询通常可以更快速地完成,因为他们需要阅读的数据库数据块要少得多。
使用 sql*load 加载 100 万数据:
表名
行数
路径
是否是压缩的
消耗的时间
test_nocom
1000000
直接
非压缩的
00:00:21.12
test_comp
1000000
直接
压缩的
00:00:47.77
由此可以看出, 向压缩表中加入数据的时间是正常表的一倍. 加载压缩的表所需要的额外时间来自于在数据加载过程中所执行的压缩操作。
可以得出的结论是: 在很少改变的表上使用压缩技术还是可以的. 表中数据经常变动的情况下, 尽量不要使用表压缩, 它影响插入操作.
感谢各位的阅读!关于“oracle 如何实现压缩表”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!