oracle如何实现压缩表

技术oracle如何实现压缩表这篇文章给大家分享的是有关oracle如何实现压缩表的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。表压缩是如何工作的在Orcle9i第2版中,表压缩特性通过删除在

这篇文章是关于oracle如何实现压缩表的。我觉得边肖很实用,就和大家分享一下作为参考。让我们跟着边肖看一看。

表压缩是如何工作的

在Orcle9i版本2中,表压缩功能通过删除数据库表中的重复数据值来节省空间。压缩在数据库的块级执行。当确定要压缩表时,数据库在每个数据库数据块中保留空间,以便存储出现在数据块中多个位置的数据的单个副本。这个保留的空间称为符号表。标识为要压缩的数据只存储在符号表中,而不存储在数据库行本身中。当标识为要压缩的数据出现在数据库行中时,该行将存储指向符号表中相关数据的指针,而不是数据本身。通过删除表中数据值的冗余副本来节省空间。

对于用户或应用程序开发人员来说,表压缩的效果是透明的。无论表是否被压缩,开发人员都以相同的方式访问表,因此当您决定压缩表时,您不需要修改SQL查询。表压缩的设置通常由数据库管理人员或设计人员来配置,几乎不需要开发人员或用户的参与。

1.表级别:

1.1创建一个压缩表:

创建表时使用COMPLATE关键字,该关键字指示Oracle数据库尽可能以压缩格式存储表中的行。

SQL创建表tmp_test

(身份证号码,电话号码2(20),创建时间日期)

压缩;

1.2修改现有表为压缩表:

SQLalter表tmp_test压缩;

解压缩表格:

SQLalter表tmp _ test no compresses;

1.3确定表是否被压缩:

确定表是否被压缩,查询user _ tables,压缩字段指示表是否被压缩。

SQLselect table_name,从user_tables中压缩,其中table_name不像“BIN %”;

表_名称压缩

- -

CLASSESENABLED

ROOMSENABLED

学生禁用

主_STATSDISABLED

"EN-US">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如何实现压缩表”这篇文章就分享到这里了,希望

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/83263.html

(0)

相关推荐

  • 第四章学习笔记,20191213兰毅达)

    技术第四章学习笔记,20191213兰毅达) 第四章学习笔记(20191213兰毅达)第四章学习笔记一、概述
    本章论述了并发编程,介绍了并行计算的概念,指出了并行计算的重要性;比较了顺序算法与并行算法以

    礼包 2021年10月28日
  • 用锲而不舍造句,锲而不舍的“而”字是什么意思

    技术用锲而不舍造句,锲而不舍的“而”字是什么意思“而”应为表假设的连词用锲而不舍造句。 这个词来自“锲而舍之,朽木不折,锲而不舍,金石可镂”(《劝学》-荀子); 我们再来看而的用法,“而”在文言文中常用作连词,但连词的关

    生活 2021年10月24日
  • 大戴礼记,什么是辟谷

    技术大戴礼记,什么是辟谷说到辟谷大戴礼记,相信大家多数人都会认为,辟谷就是绝食,其实辟谷是一种养生方法,而绝食是属于一种心理障碍,或者是疾病引起的无法正常进食。“辟谷”源自道家养生中的“不食五谷”,是古人常用的一种养生方

    生活 2021年10月28日
  • 如何理解一致性hash算法和实现

    技术如何理解一致性hash算法和实现本篇文章给大家分享的是有关如何理解一致性hash算法和实现,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。一致性hash算

    攻略 2021年11月24日
  • oracle数据库安装前需要如何配置环境

    技术oracle数据库安装前需要如何配置环境小编给大家分享一下oracle数据库安装前需要如何配置环境,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!系统版本redhat5.6一 安装前环境配置查看内存g

    攻略 2021年11月18日
  • 端口扫描工具AutoRecon怎么用

    技术端口扫描工具AutoRecon怎么用这篇文章给大家介绍端口扫描工具AutoRecon怎么用,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。今天给大家推荐一款端口扫描工具:AutoRecon一、环境

    攻略 2021年12月10日