OLTP 表压缩

压缩始终是非常占用CPU的过程,并且需要花费一定时间,通常,如果压缩数据,则数据必须解压缩后才能使用。虽然此要求在数据仓库环境中是可以接受的但在OLTP环境中可能无法接受

现在,在Oracle数据库11g中,可以执行以下命令:

create table my_compressed_table (
  col1 number(20),
  col2 varchar2(300),
  ...
)
compress for all operations

“compress for all operations”子句在所有DML活动(如 INSERT、UPDATE等)上执行压缩,压缩在所有DML活动上发生,而不像oracle11g之前的版本那样,只在直接路径加载上发生

OLTP table compress的原理

当我们对一个表使用alter table <<table_name>> compress for oltp语句时,对已有的数据不受影响。但是他对一个块中新insert或update的行最开始也不受影响,直到这个数据块达到PCTFREE时才触发压缩,于是,现在新的压缩其实就是从老的方法:对每条新增的行做compress,变成了对一个block中的所有行批量处理,这样就让大部分的insert/update语句没有性能上的损失,只对insert/update导致某个块刚好达到PCTFREE的语句有一些负载

当一个块由于触发压缩,而导致块的数据又低于PCTFREE的临界点后,这个块又可以接受更多的数据,会又一次达到PCTFREE,就会又一次压缩

由于压缩作为触发事件发生,而不是在插入行时发生,因此在正常的DML进程中压缩对性能没有任何影响。压缩被触发后,对CPU的需求肯定会变得很高,但在其他任何时间CPU影响都为零,因此压缩也适用于OLTP应用程序

OLTP compressed table和传统老的compressed table的空间利用情况的比较

conn /as sysdba
grant select on dba_objects to scott; conn scott/tiger
create table newcomp compress for oltp as select * from dba_objects;
create table oldcomp compress as select * from dba_objects;
create table notcomp as select * from dba_objects; select table_name, compress_for from user_Tables where table_name in ('NEWCOMP','OLDCOMP','NOTCOMP'); select segment_name, sum(bytes)/1024 KB from user_extents where segment_name in ('NEWCOMP','OLDCOMP','NOTCOMP') group by segment_name;

两种压缩方式在最开始的时候差不多大

update newcomp set object_name = object_name||'abc';
update oldcomp set object_name = object_name||'abc';
update notcomp set object_name = object_name||'abc';
commit; select segment_name, sum(bytes)/1024 KB from user_extents where segment_name in ('NEWCOMP','OLDCOMP','NOTCOMP') group by segment_name;

在大量更新后,我们发现,传统的表压缩逐渐丢失了自己压缩的特性,而OLTP compressed table却依然保持良好的压缩性能

drop table OLDCOMP purge;
drop table NEWCOMP purge;
drop table NOTCOMP purge;

收缩段

SQL> grant select on dba_objects to scott;

SQL> conn scott/tiger
SQL> create table t as select * from dba_objects;
SQL> create index ind_t on t(object_id); SQL> exec dbms_stats.gather_table_stats('scott', 't', cascade=>true);
SQL> select num_rows, blocks from user_tables where table_name='T';
SQL> delete t where rownum<=30000;
SQL> commit; SQL> exec dbms_stats.gather_table_stats('scott', 't', cascade=>true);
SQL> select num_rows, blocks from user_tables where table_name='T'; SQL> alter table t enable row movement;
SQL> alter table t shrink space compact;
SQL> exec dbms_stats.gather_table_stats('scott', 't', cascade=>true);
SQL> select num_rows, blocks from user_tables where table_name='T'; SQL> alter table t shrink space;
SQL> exec dbms_stats.gather_table_stats('scott', 't', cascade=>true);
SQL> select num_rows, blocks from user_tables where table_name='T'; SQL> select status from user_indexes where table_name='T' --段收缩之后索引仍然有效(valid);
SQL> delete t;
SQL> commit; SQL> alter table t shrink space;----默认执行两步
SQL> exec dbms_stats.gather_table_stats('scott', 't', cascade=>true);
SQL> select num_rows, blocks from user_tables where table_name='T';

处理挂起的事务
暂停失败的事物,不要回退,处理故障后继续运行源语句(9i的新特性)
当事务缺少某些资源不能运行的时候数据库会有两种处理方法:
一:自动的回退,当我们运行大的事物时,回退是很大的工作量
二:数据库可以将事物挂起,等待新的资源到来,继续进行处理没有完成的事物,我们可以设置等待的时间,可以检测等待的资源

SQL> drop tablespace t2m including contents and datafiles;
SQL> create tablespace t2m datafile '/u01/app/oracle/oradata/orcl/t2m.dbf' size 1m autoextend off; SQL> conn scott/tiger
SQL> drop table e purge;
SQL> create table e tablespace t2m as select * from emp;
SQL> insert into e select * from e; SQL> /
insert into e select * from e
ORA-01653: 表 SCOTT.E 无法通过 8 (在表空间 T2M 中) 扩展

只回退当前的语句,其他插入还在,等待我们结束事务。

conn /as sysdba
SQL> grant execute on dbms_resumable to scott;
SQL> grant resumable to scott; conn scott/tiger
SQL> alter session enable resumable timeout 3600;

启用挂起的特性

conn /as sysdba
grant select on v_$mystat to scott;
SQL> select sid from v$mystat where rownum=1;
--查看当前的会话
SQL> select dbms_resumable.get_session_timeout(151) from dual;
SQL> insert into e select * from e;
--现在挂起不动了,等待资源,我们新开一个会话
SQL> conn system/a
SQL> select event from v$session_wait where sid=151;
--看151会话在等待什么
SQL> select error_msg from dba_resumable; SQL> select file_id from dba_data_files where tablespace_name='T2M';
SQL> alter database datafile 7 resize 3m; --再回到第一个会话,我们看到
14336 rows inserted
SQL> commit;

OCP读书笔记(18) - 空间管理的更多相关文章

  1. 存储器的保护(一)——《x86汇编语言:从实模式到保护模式》读书笔记18

    本文是原书第12章的学习笔记. 说句题外话,这篇博文是补写的,因为让我误删了,可恶的是CSDN的回收站里找不到! 好吧,那就再写一遍,我有坚强的意志.司马迁曰:“文王拘而演<周易>:仲尼厄 ...

  2. OCP读书笔记(12) - 执行闪回数据库

    闪回数据库使用的是闪回日志,闪回日志存在于闪回目录(也就是快速闪回区中)闪回日志:就是数据块修改之前的镜像,简称前像 1.查看闪回目录的位置:show parameter recovery 如果闪回目 ...

  3. OCP读书笔记(2) - 配置恢复

    RMAN的命令类型 1. sqlplus命令 [oracle@oracle admin]$ export ORACLE_SID=orcl [oracle@oracle admin]$ rman tar ...

  4. OCP读书笔记(19) - 数据库空间管理

    传输表空间:将linux下的数据库中的test表空间传输到windows平台下的数据库 在传输表空间前,先确定一下源库与目标数据库字符集一致: select * from nls_database_p ...

  5. OCP读书笔记(13) - 管理内存

    SGA 1. 什么是LRULRU表示Least Recently Used,也就是指最近最少使用的buffer header链表LRU链表串联起来的buffer header都指向可用数据块 2. 什 ...

  6. OCP读书笔记(14) - 管理数据库性能

    搜集统计信息 1. dbms_stats gather_schema_stats 1)option:有四个选项: a.gather empty:只分析目前还没有搜集过统计信息的表 SQL> co ...

  7. OCP读书笔记(16) - 管理资源

    使用者组 创建资源用户组OLTP_GRP,将用户HR,OE加入此组: BEGIN dbms_resource_manager.clear_pending_area(); dbms_resource_m ...

  8. OCP读书笔记(15) - 管理SQL性能调优

    SQL Tuning Advisor(STA): 使用oracle提供的程序包进行sql优化 SQL> conn scott/tiger SQL), name )); SQL> inser ...

  9. 《Linux内核设计与实现》读书笔记 18

    第十八章调试 18.1 准备开始 一个bug:大部分bug通常都不是行为可靠而且定义明确的 一个藏匿bug的内核版本:找出bug首先出现的版本 相关内核代码的知识和运气 18.2内核中的bug 可以有 ...

随机推荐

  1. js与DOM初步:访问html元素

    1.DOM简介 DOM= Document Object Model,文档对象模型,DOM可以以一种独立于平台和语言的方式访问和修改一个文档的内容和结构.换句话说,这是表示和处理一个HTML或XML文 ...

  2. poj1011Sticks

    传说中的poj必做50题之中的一个-- 这是个传说中的搜索, 一開始以为, 仅仅要棒子加起来等于如果的原始长度, 那么这几根选择的棒子就不用管了, 结果卡在第一个例子-- 看了一下,发现, 代码把1, ...

  3. 关键部分CCriticalSection使用

    类CCriticalSection的对象表示一个“临界区”,它是一个用于同步的对象,同一时刻仅仅同意一个线程存取资源或代码区.临界区在控制一次仅仅有一个线程改动数据或其他的控制资源时很实用.比如,在链 ...

  4. ExtJs4 笔记(8) Ext.slider 滚轴控件、 Ext.ProgressBar 进度条控件、 Ext.Editor 编辑控件

    本篇要登场的有三个控件,分别是滚轴控件.进度条控件和编辑控件. 一.滚轴控件 Ext.slider 1.滚轴控件的定义 下面我们定义三个具有代表意义滚轴控件,分别展示滚轴横向.纵向,以及单值.多值选择 ...

  5. windows7 iis安装与配置

    方法/步骤   一. Windows 7环境下的安装配置 打开控制面板——程序和功能   点击左侧“打开或关闭Windows功能”,弹出Windows功能 对话框.   在Windows功能对话框中进 ...

  6. Oracle dump 分析secondary key

    验证secondary key 含有主键列数据 SQL> select object_name,object_id,OBJECT_TYPE from user_objects; OBJECT_N ...

  7. java web从零单排第十六期《struts2》控制标签(2)

    1.s:subset标签概述: s:subset标签功能是从一个集合中取出部分元素合并成一个新的集合,新生成的这个集合是原来集合的子集.属性和意义如下: 属性名 是否必需 默认值 类型 说明介绍 co ...

  8. form不提交问题

    var confirmOrderForm=document.getElementById("confirmOrderForm"); var url="${pageCont ...

  9. html浏览器兼容性的 JavaScript语法

    1.      在FireFox中能够使用与HTML节点对象ID属性值同样的JS变量名称.可是IE中不行. 解决的方法:在命名上区分HTML节点对象ID属性值和JS变量 2.      IE不支持JS ...

  10. [Android学习笔记]RelativeLayout的使用

    RelativeLayout是相对布局控件,在屏幕适配的时候非常有用,在此记录一些它的常用属性 第一类:属性值为true或falseandroid:layout_centerHrizontal     ...