从Oracle9iR2 开始,ORACLE提供了表/表空间压缩技术,以减少磁盘开销,节省空间,并在某些情况下提高查询性能。
表压缩是如何工作的在Orcle9i第2版中,表压缩特性通过删除在数据库表中发现的重复数据值来节省空间。压缩是在数据库的数据块级别上进行的。当确定一个表要被压缩后,数据库便在每一个数据库数据块中保留空间,以便储存在该数据块中的多个位置上出现的数据的单一拷贝。这一被保留的空间被称作符号表(symbol table)。被标识为要进行压缩的数据只存储在该符号表中,而不是在数据库行本身内。当在一个数据库行中出现被标识为要压缩的数据时,该行在该符号表中存储一个指向相关数据的指针,而不是数据本身。节约空间是通过删除表中数据值的冗余拷贝而实现的。
1.表级别
1.1 创建一个压缩表:创建表时使用COMPRESS关键字,COMPRESS关键字指示Oracle数据库尽可能以压缩的格式存储该表中的行。
create table test compress as select * from dba_objects where 1=2; create table test (id number,name varchar2(20),time date) compress;
1.2 修改现有表为压缩表:
SQL> alter table test compress;
取消表的压缩:
SQL> alter table 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创建表压缩空间
create tablespace TEST datafile '/export/home/oracle/ora10g/oradata/test/test.dbf' size 10M default compress
与其他存储参数类似,COMPRESS属性也具有一些继承特性。当在一个表空间中创建一个表时,它从该表空间继承COMPRESS属性。
2.2.使现有表空间转换为压缩表空间
SQL> alter tablespace test default compress; SQL> alter tablespace test 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种方法时,表中的数据才会被压缩存放:
(1).直接路径的 sql*load
(2).带有/*+ append*/的 insert语句
(3).create table .. as select..
· (4).并行insert
4.压缩一个已经存在但并未压缩的表
使用alter table .. move compress使一个已存在但未压缩的表转换为压缩表.
SQL> alter table tmp_test move compress;
同样,也可以使用alter table.. move nocompress来解压一个已经压缩的表:
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 9iR2 开始,Oracle 提供了表/表空间压缩技术,以减少磁盘开销,节省空间,并在某些情况下提高查询性能。 表压缩的工作原理是删除在数据库表中发现的重复数据值,以节省空间。压缩是在数据库的数据块级别...
6. **解压缩Oracle安装包**: - 在下载好的文件所在目录执行: ``` # unzip linux_11gR2_database_1of2.zip # unzip linux_11gR2_database_2of2.zip ``` - 确保解压后的目录对oracle用户具有读写和执行权限: ...
Oracle 11g Release 2 (11gR2) 是 Oracle 公司的一个数据库管理系统,主要用于企业级数据存储和管理。在 Linux 操作系统上安装 Oracle 11gR2 需要遵循一系列步骤,确保系统满足必要的硬件和软件要求。以下是详细的...
最后,解压缩下载的Oracle安装包,确保`oracle`用户具有足够的权限: 1. 解压ZIP文件: ``` #unzip linux_11gR2_database_1of2.zip #unzip linux_11gR2_database_2of2.zip ``` 2. 调整解压目录的权限: ``` ...
请注意,安装Oracle 11g涉及的步骤较为复杂,包括创建表空间、初始化参数文件、启动监听服务、创建数据库实例等。在安装过程中,可能还需要调整内核参数以满足Oracle的要求,如打开文件数限制、修改内存限制等。确保...
Oracle压缩表测试 从Oracle9iR2开始,Oracle推出了压缩表技术(table compression),用于压缩数据表中的重复数据,以节省存储空间,压缩技术倾向于在数据仓库中使用
此外,Oracle还提供了压缩选项,如ROW STORE COMPRESSION和COLUMN STORE COMPRESSION,可以在一定程度上减少表空间占用。 8. **监视和调整表空间**:通过使用DBA视图(如DBA_FREE_SPACE和DBA_SEGMENTS)和企业管理...
### ORACLE SYSTEM表空间已满解决方案 #### 一、SYSTEM表空间的作用 SYSTEM表空间是Oracle数据库中的一个关键组成部分,在数据库创建时会自动创建。它包含了许多重要的数据库元数据和控制信息,对于数据库的正常...
### Oracle表空间与数据文件详解 #### 一、Oracle表空间与数据文件的概念 在Oracle数据库中,**表空间**是存储数据的基本单位之一,它是一个或多个数据文件的逻辑集合。表空间提供了数据存储的逻辑视图,而数据...
#### 步骤六:解压缩 Oracle 安装文件 1. 将安装文件从光驱拷贝至 `/usr/src` 目录: ```sh cp /mnt/cdrom/linux81701.tar /usr/src ``` 2. 解压文件: ```sh tar xvf linux81701.tar ``` 3. 生成 Disk1 目录...
- **空间优化**:对于空间使用率较高的表,考虑使用压缩技术或者重新组织表结构来减少占用空间。 - **备份与恢复**:在进行任何空间管理操作之前,务必做好数据备份,以防万一出现问题时能够迅速恢复数据。 综上所...
1. 下载完成后,解压缩到指定目录。 2. 运行Eclipse,首次启动时会提示选择工作空间。 3. 根据个人习惯设置工作空间的位置。 #### 三、Android SDK Android SDK包含了开发Android应用所需的各种工具和库,如模拟器...
### 查询一个Oracle表所占的物理空间大小 在Oracle数据库管理中,了解特定表占用的物理空间大小对于优化存储、规划磁盘空间以及提高数据库性能至关重要。本文将详细介绍如何查询一个Oracle表所占的物理空间大小,...
Oracle 普通表转分区表方式 Oracle 分区表(Partitioned Table)是一种特殊的表结构,可以根据不同的条件将数据分割成多个独立的分区,以提高查询效率和减少存储空间。本文将详细介绍将 Oracle 普通表转换为分区表...
### Oracle 查看表空间表信息 在Oracle数据库管理中,了解如何查看表空间表信息是一项重要的技能。这有助于DBA(数据库管理员)或开发人员更好地理解数据库结构、优化查询性能以及进行必要的维护工作。 #### 标题...
在Oracle数据库系统中,表空间(Tablespace)是存储数据对象如表、索引、视图等的基础单元。管理表空间对于确保数据库高效运行至关重要。本文将深入探讨Oracle表空间的回收过程,并提供一个可能的回收脚本示例。 1....
【Oracle 数据库传输表空间的数据压缩解决方案】 在Oracle数据库中,数据压缩是一种有效的节省存储空间的方法,尤其在处理大量数据时。本文针对某电信计费系统由于业务政策导致的数据量急剧增长,影响了系统的稳定...
在本文中,我们将详细探讨如何在 Solaris 9 操作系统上安装和维护 Oracle 9 数据库。首先,我们需要了解安装 Oracle 9 所需的硬件配置要求。 1. **硬件配置要求**: - 内存:至少 512MB - 交换空间(Swap Space)...
- 确保ORACLE_HOME至少有2.54GB的可用空间,/tmp目录需要约700MB的空间。 4. **用户与目录管理**: - 添加DBA组:`# groupadd dba` - 创建用户oracle并指定其主目录和组:`# useradd -d /oracle10 -g dba oracle...
在IBM AIX操作系统上部署Oracle数据库前,首要任务是确保有充足的磁盘空间,并为此创建一个专用的文件系统。文件系统`/oracle`的配置如下: - **文件系统名称**:`/oracle` - **挂载点**:`/oracle` - **文件系统...