如何移动表来达到减小数据文件大小的目的

原创 2004年06月11日 10:21:00

Author:Kamus
Mail:
kamus@itpub.net
Date:2004-4

通过move tablespace来完成resize datafile。
HWM的概念就不在此阐述了。

测试环境为Oracle10g for Linux,其它版本的一样。

我们先创建两个表空间,分别为t_tbs和t_tbs1,分别有一个数据文件,大小都是5M
再创建一个test_user用户,给这个用户上述两个表空间的无限限额,并且设置默认表空间是t_tbs。
[zhangleyi@as zhangleyi]$ sqlplus / as sysdba

SQL*Plus: Release 10.1.0.2.0 - Production on Tue Apr 13 21:01:25 2004

Copyright (c) 1982, 2004, Oracle.  All rights reserved.


Connected to:
Oracle Database 10g Enterprise Edition Release 10.1.0.2.0 - Production
With the Partitioning, OLAP and Data Mining options

SYS at orcl10>alter user test_user default tablespace t_tbs;

User altered.

SYS at orcl10>alter user test_user quota unlimited on t_tbs;

User altered.

SYS at orcl10>alter user test_user quota unlimited on t_tbs1;

User altered

用test_user登录,创建表
TEST_USER at orcl10>create table t_obj as select * from dba_objects where rownum<10000;

Table created.

TEST_USER at orcl10>insert into t_obj select * from t_obj;

9999 rows created.

TEST_USER at orcl10>/

19998 rows created.

TEST_USER at orcl10>/
insert into t_obj select * from t_obj
*
ERROR at line 1:
ORA-01653: unable to extend table TEST_USER.T_OBJ by 128 in tablespace T_TBS


TEST_USER at orcl10>commit;

Commit complete.

TEST_USER at orcl10>select sum(blocks) "Total Blocks",sum(bytes) "Total Size" from dba_extents where owner='TEST_USER' and segment_name='T_OBJ';

Total Blocks Total Size
------------ ----------
         512    4194304

好,上面我们创建了一个表,并且插入了很多数据,通过dba_extents视图我们可以看到总共用的block数和总共的大小。

下面我们用delete删除全部数据,并且插入新的9999条数据
TEST_USER at orcl10>delete from t_obj;

39996 rows deleted.

TEST_USER at orcl10>insert into t_obj select * from dba_objects where rownum<10000;

9999 rows created.

TEST_USER at orcl10>commit;

Commit complete.

TEST_USER at orcl10>select sum(blocks) "Total Blocks",sum(bytes) "Total Size" from dba_extents
  2  where owner='TEST_USER' and segment_name='T_OBJ';

Total Blocks Total Size
------------ ----------
         512    4194304

再次查看dba_extents视图,发现占用的空间并没有减少。

我们尝试resize这个数据文件,file#为6的是t_tbs表空间下面的数据文件
SYS at orcl10>alter database datafile 6 resize 4M;
alter database datafile 6 resize 4M
*
ERROR at line 1:
ORA-03297: file contains used data beyond requested RESIZE value


SYS at orcl10>alter database datafile 6 resize 4500000;

Database altered.

我们发现想resize到4M不可以,但是resize到4500000就可以了,因为上面查看出来的Total Size是4194304,这个值大于4M而小于4500000。

然后我们move这张表到t_tbs1表空间,这个表空间下面的数据文件file#是8

EST_USER at orcl10>alter table t_obj move tablespace t_tbs1;

Table altered.

TEST_USER at orcl10>select sum(blocks) "Total Blocks",sum(bytes) "Total Size" from dba_extents
  2  where owner='TEST_USER' and segment_name='T_OBJ';

Total Blocks Total Size
------------ ----------
         128    1048576

我们检查dba_extents视图,发现Total Size已经变化了,此时已经可以说明move表是会重新进行block的整理的,同时也重置了HWM。

下面我们resize这个数据文件。
SYS at orcl10>alter database datafile 8 resize 3M;

Database altered.

SYS at orcl10>host
[zhangleyi@as ORCL10]$ cd /oracle/oradata/ORCL10/datafile/
[zhangleyi@as datafile]$ ls -l
总用量 1419076
-rw-r-----    1 zhangleyi dba      20979712  4月 13 21:17 cattbs01.dbf
-rw-r-----    1 zhangleyi dba      157294592  4月 13 21:17 o1_mf_example_02p0gpoj_.dbf
-rw-r-----    1 zhangleyi dba      419438592  4月 13 21:20 o1_mf_sysaux_02p09kny_.dbf
-rw-r-----    1 zhangleyi dba      555753472  4月 13 21:17 o1_mf_system_02p09kno_.dbf
-rw-r-----    1 zhangleyi dba      20979712  4月 13 21:02 o1_mf_temp_02p0fzsd_.tmp
-rw-r-----    1 zhangleyi dba      62922752  4月 13 21:20 o1_mf_undotbs1_02p09kog_.dbf
-rw-r-----    1 zhangleyi dba      209723392  4月 13 21:17 o1_mf_users_02p09kqv_.dbf
[color=red]-rw-r-----    1 zhangleyi dba       3153920  4月 13 21:21 TEST01.DBF[/color]
[color=red]-rw-r-----    1 zhangleyi dba       4513792  4月 13 21:20 test.dbf[/color]

可以看到我们的目的已经达到了。

在真实应用中,我们可以将一个表空间中的所有object,全部move到一个新的表空间中,然后drop掉原来的表空间,再从磁盘上删除原来表空间中的数据文件。

至于如何得知HWM,我们可以通过analyze之后的数据字典得到,那么如果不进行analyze的话,我们也可以运行下面这个脚本。
这个脚本可以用于检查一个object占有的总共block数和处于HWM之上的block数,这当然也就知道了HWM是在什么位置。

DECLARE
v_total_blocks NUMBER;
v_total_bytes NUMBER;
v_unused_blocks NUMBER;
v_unused_bytes NUMBER;
v_last_used_extent_file_id NUMBER;
v_last_used_extent_block_id NUMBER;
v_last_used_block NUMBER;
BEGIN
dbms_space.unused_space('SCOTT','BIGEMP','TABLE',v_total_blocks,v_total_bytes,v_unused_blocks,v_unused_bytes,v_last_used_extent_file_id,v_last_used_extent_block_id,v_last_used_block);
dbms_output.put_line('Total Blocks: '||TO_CHAR(v_total_blocks));
dbms_output.put_line('Blocks above HWM: '||TO_CHAR(v_unused_blocks));
END;
/

Total Blocks: 256
Blocks above HWM: 0

PL/SQL procedure successfully completed

Executed in 0.01 seconds

Oracle 中减小数据文件大小

      可以通过resize datafile来减小数据文件的大小。      首先,要查清楚数据文件的真实使用空间。可以通过查询dba_extents达到这个目的。oatbs表空间使用的数据文件...
  • rznice
  • rznice
  • 2010年12月30日 17:13
  • 6865

减少 JPG 文件大小

减少 JPG 文件大小如果你是一个现代的开发者,无论你是网站开发、移动开发、还是一些奇怪的系统管理程序,你一定会使用 JPG 文件。JPG 是你工作的一部分,并且对于用户体验有着极其重要...
  • asdzheng
  • asdzheng
  • 2016年06月28日 22:04
  • 2353

如何优化PNG,JPG图片减小图片文件大小

PNG(Portable Network Graphic Format,PNG)图片是一种图像文件存储格式,其目的是试图替代GIF和TIFF文件格式,同时增加一些GIF文件格式所不具备的特性。PNG用...
  • bestkilly
  • bestkilly
  • 2016年09月01日 10:59
  • 802

如何减少PDF文件的大小,为pdf瘦身?

方法 1: 使用Adobe Acrobat Pro来减少文件大小 启动Adobe Acrobat Pro(注意:Adobe Acrobat的免费版程序没有相关功能)。...
  • yangle20081982
  • yangle20081982
  • 2014年04月30日 10:45
  • 20506

减少可执行程序的大小

一、背景 可执行程序需要链接一些静态库,但是静态库中的函数并没有全部使用,只用了其中的几个,但是系统默认会自动把整个静态库全部链接到可执行程序中,造成可执行程序的大小大大增加,浪费了...
  • CodeHeng
  • CodeHeng
  • 2016年07月01日 16:35
  • 1445

减小Delphi的Exe文件大小

一般来说,由Delphi生成的EXE文件,要比其由它编程语言生成的体积大一些。这主要是由于使用VCL的原因(当然,VCL是有许多优点的!)  以下是减小EXE文件大小的几种途径:  01)...
  • diligentcat
  • diligentcat
  • 2014年06月15日 22:17
  • 1039

C/C++程序减小可执行文件的大小

Matt Pietrek is the author of Windows 95 System Programming Secrets (IDG Books, 1995). He works at N...
  • paschen
  • paschen
  • 2016年12月08日 23:45
  • 1347

如何减小编译后可执行文件的大小

  CFLAGS += -ffunction-sections -fdata-sections LDFLAGS += -Wl,-Map=object.map,--cref,--gc-section i...
  • hansel
  • hansel
  • 2011年02月12日 11:42
  • 2441

设置大小合适的Win7休眠文件Hiberfil.SYS

Hiberfil.SYS 是 Windows 休眠功能(Windows Hibernation)将内存数据与会话保存至硬盘、以便计算机断电重新启动后可以快速恢复会话所需的内存镜像文件。在早期版本的 ...
  • HarbinZJU
  • HarbinZJU
  • 2011年12月04日 15:33
  • 10082

减小文件大小

Unity post-processes all imported assets Unity后处理所有导入的资源 Unity always post-processes imported fil...
  • u012487582
  • u012487582
  • 2015年04月01日 11:03
  • 212
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:如何移动表来达到减小数据文件大小的目的
举报原因:
原因补充:

(最多只允许输入30个字)