压缩表
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小了将近一半的数据量。

相关内容

热门资讯

我来教教您“哈灵斗地主可以开挂... 您好:哈灵斗地主这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9752949】很多玩家在这款游...
终于了解“花花生活圈真的有挂吗... 有 亲,根据资深记者爆料花花生活圈是可以开挂的,确实有挂(咨询软件无需打...
【第一财经】“微乐锄大贰有挂吗... 【第一财经】“微乐锄大贰有挂吗?”(其实是有挂)您好,微乐锄大贰这个游戏其实有挂的,确实是有挂的,需...
终于了解“微竞棋牌可以开挂吗?... 网上科普关于“微竞棋牌有没有挂”话题很是火热,小编也是针对微竞棋牌作*弊开挂的方法以及开挂对应的知识...
纯米科技取得微波炉专利,优化腔... 国家知识产权局信息显示,纯米科技(上海)股份有限公司取得一项名为“一种微波炉”的专利,授权公告号CN...
今日重大消息“情怀莆仙开挂神器... 网上科普关于“情怀莆仙有没有挂”话题很是火热,小编也是针对情怀莆仙作*弊开挂的方法以及开挂对应的知识...
今日重大发现“新圣游炸/金/花... 有 亲,根据资深记者爆料新圣游炸/金/花是可以开挂的,确实有挂(咨询软件...
玩家攻略科普“大玩家十三水怎么... 您好:大玩家十三水这款游戏可以开挂,确实是有挂的,需要了解加客服微信【9784099】很多玩家在这款...
今日重大消息“天涯麻将怎么装挂... 网上科普关于“天涯麻将有没有挂”话题很是火热,小编也是针对天涯麻将作*弊开挂的方法以及开挂对应的知识...
【第一消息】“山西扣点点真的有... 家人们!今天小编来为大家解答山西扣点点透视挂怎么安装这个问题咨询软件客服徽9752949的挂在哪里买...