压缩表
admin
2023-04-14 22:21:18
0

通常我们可以使用 COMPRESS子句或COMPRESS BASIC子句来启用表的基本压缩特性(COMPRESS子句和COMPRESS BASIC子句的作用是相同的),从性能的角度来说,使用基本压缩的主要优势在于,如果数据压缩后再加载,接下来的任何 I/O操作都会使用更少的资源,因为在读写数据时需要访问更少的数据块。一般来说,存储大量字符数据的表适合使用基本压缩。Oracle的基本压缩属性对于正常的DML语句,例如INSERTUPDATEMERGEDELETE没有影响。如果你希望对所有DML语句起作用,那么就要考虑使用OLTP压缩。COMPRESS FOR OLTP子句为所有DML操作启用压缩。OLTP压缩并不会在数据插入或修改时马上压缩,而是在数据块中的修改达到一定阈值时,成批次来进行压缩。当达到阈值时,所有未压缩的数据行将会同时进行压缩。需要进行压缩的阈值由一种内部算法(你并不能控制)决定。

同样也能够在分区和表空间级别上指定基本压缩。位于使用COMPRESS子句创建的表空间中的所有表,默认都会启用基本压缩。

可以查询相应的DBA/ALL/USER_TABLES视图的compression来验证是否对一张表启用了压缩。查询dba_tablespace视图中的tab_compressioncompress_for列检查表空间是否启用了压缩。

创建压缩表:

create table regs (reg_id number,reg_name varchar2(2000))compress;

create table regs (reg_id number,reg_name varchar2(2000))compress for oltp;

压缩表(之后的数据启用):

SQL> alter table regs_dss compress;

    SQL> alter table regs compress for oltp;


压缩表中已有数据:

SQL> alter table regs_dss move compress;

SQL> alter table regs_dss move compress for oltp;

 

解压缩:

SQL> alter table regs_dss nocompress;

SQL> alter table regs_dss nocompress for oltp;


解压缩表中已有数据:

SQL> alter table regs_dss move nocompress;

SQL> alter table regs_dss move nocompress for oltp;


创建压缩表空间

CREATE TABLESPACE comp_data

DATAFILE 1/oraOl/dbf Ile/0liR2/comp_dataOl.dbf'

SIZE 500M

EXTENT MANAGEMENT LOCAL

UNIFORM SIZE 512K

SEGMENT SPACE MANAGEMENT AUTO

DEFAULT COMPRESS;/ DEFAULT COMPRESS for oltp;

修改已有的表空间,设置其默认的压缩度:

SQL> alter tablespace comp_data default compress;

1)         创建测试表并插入数据

SQL> CREATE TABLE t (ID NUMBER,addtime DATE,mark varchar2(10) default null);

 

SQL> BEGIN

   FOR i IN 1 .. 60000

   LOOP

      INSERT INTO t(id,addtime)

           VALUES (i, sysdate);

      COMMIT;

      ---DBMS_LOCK.sleep (0.1);

   END LOOP;

END;

/

2)         查看对象大小

SQL> select segment_name, bytes/1024/1024 from dba_segments where owner='ADMIN';

 

SEGMENT_NAME              BYTES/1024/1024

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

CHAINED_ROWS                  .0625

T                                    5.8125

 

3)         使用表压缩功能创建

SQL> create table t_com compress as select * from t;

SQL> select segment_name, bytes/1024/1024 from dba_segments where owner='ADMIN';

 

SEGMENT_NAME              BYTES/1024/1024

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

T_COM                         3

CHAINED_ROWS                  .0625

T                               5.8125

t_com启用压缩后比t小了将近一半的数据量。

相关内容

热门资讯

从一座“灯塔工厂”看海辰储能的... 央广网北京5月12日消息(记者 刘家怡)在重庆市铜梁区,每天有超过10万颗储能电芯下线,发往全球市场...
东莞松山湖高新区“两创融合”催... 当科学家听懂了企业话 东莞松山湖高新区“两创融合”催生新能源新动能 问起扎根东莞松山湖的新能源企业和...
厕所内装摄像头要监控啥 澎湃新闻记者 蒋立冬 阳柳厕所内装摄像头要监控啥“中学在男厕所安装摄像头”一事引发关注。5月11日晚...
原创 港... 大家普遍认为目前的任何钢材都经不起海水的侵蚀腐蚀,但是现如今它的到来将打破这一“铁”的定律!那就是S...
会“变形”的检测机器人Haza... 近日,香港生产力促进局、中广核(深圳)运营技术与辐射监测有限公司、中山大学、西安交通大学及本末科技有...
2025年美国制造业回流追踪 创纪录的投资与关税加码之下,美国制造业在2025年依然表现不佳。但可以合理预期,已宣布的投资将在不久...
原创 风... 那天傍晚,车从草原边上开过去,天色刚压下来,远处一排排白色大风机还在慢慢转。同行的人盯着看了半天,突...
官方调查报告:司机吸食打火机气... 11日,辽阳市应急管理局发布辽阳灯塔沈营线(S101)“10·8”较大道路运输事故调查报告。2024...
赖清德窜访媚外,金门老百姓却苦... 探访厦金大桥赖清德“偷渡式”窜访,岛内民众大骂:这边民生受阻,那边你还去给外国人“跪”。反观今年4月...
特朗普访华,通用汽车和福特高层... 【文/观察者网 潘昱辰 编辑/高莘】美国总统特朗普将于5月13-15日对中国进行国事访问。据白宫披露...