压缩可以节省磁盘空间,减少数据库缓冲区缓存中的内存使用,并且可以显着加快读取期间的查询执行速度。
压缩在数据加载和 DML 的 CPU 开销方面是有代价的。然而,这个成本被减少的 I/O 需求所抵消。由于压缩的表数据在内存中保持压缩状态,因此压缩还可以提高 DML 操作的性能,因为数据库缓冲区缓存(以及闪存缓存,如果启用)可以容纳更多行。
表压缩对应用程序完全透明。它在决策支持系统 (DSS)、在线事务处理 (OLTP) 系统和档案系统中很有用。
您可以为表空间、表或分区指定压缩。如果在表空间级别指定,则默认压缩在该表空间中创建的所有表。
Table Compression Methods
Table Compression Method | Compression Level | CPU Overhead | Applications | Notes |
---|---|---|---|---|
Basic table compression |
High |
Minimal |
DSS |
None. |
Advanced row compression |
High |
Minimal |
OLTP, DSS |
None. |
Warehouse compression (Hybrid Columnar Compression) |
Higher |
Higher |
DSS |
The compression level and CPU overhead depend on compression level specified (LOW or HIGH). |
Archive compression (Hybrid Columnar Compression) |
Highest |
Highest |
Archiving |
The compression level and CPU overhead depend on compression level specified (LOW or HIGH). |
当您使用基本表压缩、仓库压缩或存档压缩时,压缩仅在数据被批量加载或数组插入到表中时发生。
基本表压缩支持有限的数据类型和 SQL 操作。
高级行压缩适用于 OLTP 应用程序并压缩由任何 SQL 操作操作的数据。当您使用高级行压缩时,在将数据插入、更新或批量加载到表中时会发生压缩。允许高级行压缩的操作包括:
-
单行插入和更新
插入和更新不会立即压缩。更新已压缩的块时,任何未更新的列通常保持压缩状态。更新的列以类似于任何未压缩块的未压缩格式存储。当块达到数据库控制的阈值时,将重新压缩更新的值。当块中的数据达到数据库控制的阈值时,插入的数据也会被压缩。
-
Array inserts
Array inserts include
INSERT INTO SELECT
SQL statements without theAPPEND
hint, and array inserts from programmatic interfaces such as PL/SQL and the Oracle Call Interface (OCI).
The following direct-path INSERT
methods:
-
Direct path SQL*Loader
-
CREATE
TABLE
AS
SELECT
statements -
Parallel
INSERT
statements -
INSERT
statements with anAPPEND
orAPPEND_VALUES
hint
Inserts performed with these direct-path INSERT
methods are compressed immediately.
无论采用何种压缩方法,压缩块上的DELETE操作都与非压缩块的DELETE操作相同。SQL DELETE操作在数据块上获得的任何空间都将被后续的SQL INSERT操作重用。使用混合柱状压缩技术,当压缩单元中的所有行都被删除时,压缩单元内的空间可供重用。
表压缩特性
Table Compression Method | CREATE/ALTER TABLE Syntax | Direct-Path or Array Inserts | Notes |
---|---|---|---|
Basic table compression |
|
Rows are compressed with basic table compression. |
Rows inserted without using direct-path or array insert and updated rows are uncompressed. |
Advanced row compression |
|
Rows are compressed with advanced row compression. |
Rows inserted with or without using direct-path or array insert and updated rows are compressed using advanced row compression. |
Warehouse compression (Hybrid Columnar Compression) |
|
Rows are compressed with warehouse compression. |
This compression method can result in high CPU overhead. Updated rows and rows inserted without using direct-path or array insert are stored in row format instead of column format, and thus have a lower compression level. |
Archive compression (Hybrid Columnar Compression) |
|
Rows are compressed with archive compression. |
This compression method can result in high CPU overhead. Updated rows and rows inserted without using direct-path or array insert are stored in row format instead of column format, and thus have a lower compression level. |
使用CREATE table语句的COMPRESS子句指定表压缩。通过在ALTER table语句中使用这些子句,可以对现有表启用压缩。在这种情况下,仅压缩启用压缩后插入或更新的数据。使用ALTER TABLE MOVE语句还可以对插入和更新的数据进行压缩,但它也会压缩现有数据。类似地,可以使用ALTER table…NOCOMPRESS语句禁用现有压缩表的表压缩。在这种情况下,所有已经压缩的数据都将保持压缩状态,新数据将在未压缩的情况下插入。
COLUMN STORE COMPRESS FOR QUERY HIGH选项是默认的数据仓库压缩模式。在Exadata存储上使用混合列压缩时,它提供了良好的压缩和性能。在负载性能至关重要的环境中,应使用COLUMN STORE COMPRESS FOR QUERY LOW选项。它的加载速度比使用COLUMN STORE COMPRESS FOR QUERY HIGH选项压缩的数据快。
COLUMN STORE COMPRESS FOR ARCHIVE LOW选项是默认的存档压缩模式。它提供了高压缩级别,非常适合于不常访问的数据。对于很少访问的数据,应使用COLUMN STORE COMPRESS FOR ARCHIVE HIGH选项。
DBMS_compression包提供的压缩顾问可以帮助您确定具有特定压缩方法的特定表的预期压缩级别。
Example
Creating a Table with Advanced Row Compression
The following example enables advanced row compression on the table orders
:
CREATE TABLE orders ... ROW STORE COMPRESS ADVANCED;
订单表的数据在直接路径INSERT、数组插入和常规DML期间被压缩。
Creating a Table with Basic Table Compression
以下语句是等效的,可以对sales_history表(数据仓库中的事实表)启用基本表压缩:
CREATE TABLE sales_history ... ROW STORE COMPRESS BASIC; CREATE TABLE sales_history ... ROW STORE COMPRESS;
经常对该表运行查询,但不需要DML。
Using Direct-Path Insert to Insert Rows Into a Table
此示例演示了使用APPEND提示,使用直接路径insert将行插入sales_history表。
INSERT /*+ APPEND */ INTO sales_history SELECT * FROM sales WHERE cust_id=8890; COMMIT;
Using an Array Insert to Insert Rows Into a Table
他的示例演示了在SQL中使用数组插入将行插入sales_history表。
INSERT INTO sales_history SELECT * FROM sales WHERE cust_id=8890; COMMIT;
此示例演示如何在PL/SQL中使用数组插入将行插入hr.jobs_test表。
DECLARE TYPE table_def IS TABLE OF hr.jobs%ROWTYPE; array table_def := table_def(); BEGIN SELECT * BULK COLLECT INTO array FROM hr.jobs; FORALL i in array.first .. array.last INSERT INTO hr.jobs_test VALUES array(i); COMMIT; END; /
注意:使用混合列压缩(仓库和归档),对于要立即压缩的SQL、PL/SQL或OCI中执行的数组插入,表必须存储在启用自动段空间管理(ASSM)的本地管理表空间中,并且数据库兼容级别必须为12.2.0或更高。
Creating a Table with Warehouse Compression使用仓库压缩创建表
此示例在表sales_history上启用混合列压缩:
CREATE TABLE sales_history ... COLUMN STORE COMPRESS FOR QUERY;
该表是使用默认的COLUMN STORE COMPRESS FOR QUERY HIGH选项创建的。此选项提供比基本表压缩或高级行压缩更高级别的压缩。当对该表运行频繁的查询并且不需要DML时,它工作得很好。
Creating a Table with Archive Compression使用存档压缩创建表
以下示例在表sales_history上启用混合列压缩:
CREATE TABLE sales_history ... COLUMN STORE COMPRESS FOR ARCHIVE;
使用默认的COLUMN STORE COMPRESS FOR ARCHIVE LOW选项创建表格。此选项提供比基本、高级行或仓库压缩更高级别的压缩。当负载性能非常关键且数据访问不频繁时,它可以很好地工作。默认的“COLUMN STORE COMPRESS FOR ARCHIVE LOW”选项提供的压缩级别低于“COLUM STORE CONPRESS of ARCHIVE HIGH”选项。
Compression and Partitioned Tables
一个表可以有压缩分区和未压缩分区,不同的分区可以使用不同的压缩方法。如果表及其某个分区的压缩设置不匹配,则分区设置优先于该分区。
要更改分区的压缩方法,请执行以下操作之一:
- 要仅更改新数据的压缩方法,请使用ALTER TABLE…MODIFY PARTITION…COMPRESS。。。
- 要更改新数据和现有数据的压缩方法,请使用ALTER TABLE…MOVE PARTITION…COMPRESS…或联机表重新定义。
执行这些语句时,请指定压缩方法。例如,运行以下语句将新数据和现有数据的压缩方法更改为高级行压缩:
ALTER TABLE ... MOVE PARTITION ... ROW STORE COMPRESS ADVANCED...
确定表是否已压缩
In the *_TABLES
data dictionary views, compressed tables have ENABLED
in the COMPRESSION
column.
对于分区表,此列为空,*_TAB_PARTITIONS视图的COMPRESSION列指示压缩的分区。此外,COMPRESS_FOR列指示表或分区使用的压缩方法。
SQL> SELECT table_name, compression, compress_for FROM user_tables; TABLE_NAME COMPRESSION COMPRESS_FOR ---------------- ------------ ----------------- T1 DISABLED T2 ENABLED BASIC T3 ENABLED ADVANCED T4 ENABLED QUERY HIGH T5 ENABLED ARCHIVE LOW
SQL> SELECT table_name, partition_name, compression, compress_for FROM user_tab_partitions; TABLE_NAME PARTITION_NAME COMPRESSION COMPRESS_FOR ----------- ---------------- ----------- ------------------------------ SALES Q4_2004 ENABLED ARCHIVE HIGH ... SALES Q3_2008 ENABLED QUERY HIGH SALES Q4_2008 ENABLED QUERY HIGH SALES Q1_2009 ENABLED ADVANCED SALES Q2_2009 ENABLED ADVANCED
Determining Which Rows Are Compressed确定压缩哪些行
要确定行的压缩级别,请使用DBMS_compression包中的GET_compression_TYPE函数。
例如,以下查询返回hr.employees表中某行的压缩类型:
SELECT DECODE(DBMS_COMPRESSION.GET_COMPRESSION_TYPE( ownname => 'HR', tabname => 'EMPLOYEES', subobjname => '', row_id => 'AAAVEIAAGAAAABTAAD'), 1, 'No Compression', 2, 'Advanced Row Compression', 4, 'Hybrid Columnar Compression for Query High', 8, 'Hybrid Columnar Compression for Query Low', 16, 'Hybrid Columnar Compression for Archive High', 32, 'Hybrid Columnar Compression for Archive Low', 4096, 'Basic Table Compression', 'Unknown Compression Type') compression_type FROM DUAL;
待续、、、、、、、
标签:compression,压缩,COMPRESS,TABLE,STORE,Compression From: https://www.cnblogs.com/wonchaofan/p/16736222.html