动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息



本月文章推荐
.有关forms存盘前数据合法性的检查.
.ORACLE DATE和TIMESTAMP数据类型.
.Oracle 9i切换数据库的日志模式.
.获得Oracle各内存段的内部信息(.
.管理Oracle OLAP时清除通往OLAP的.
.ORA-00600 [2662]错误解决过程.
.用PL/SQL和Java开发Oracle8 i应用.
.bin目录下各文件意义及使用方法.
.关于约束、CASE语句和游标的一些.
.如何释放过度占用的Shrink Undo表.
.J2ME 带给移动支付的优势解析.
.Oracle PL/SQL入门之案例实践.
.Oracle 9i 视图.
.为什么编译的时候提示不支持Berk.
.临时表在Oracle数据库与SQL Serv.
.旧数据文件,旧控制文件,新日志.
.Oracle基本数据类型存储格式浅析.
.在redhat Linux9下安装Oracle9.2.
.Oracle AS 10g 下部署 ColdFusio.
.专家调优秘密之改善Oracle数据库.

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

发表日期:2008-2-9 |



  通过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
上一篇:索引为什么比表大 -- 简单的Case Study 人气:772
下一篇:相当方便快速消除行迁移的表的方法 人气:496
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-24 Sablog-X v2.0 预览版
2008-7-24 帝国备份王EmpireBak 2008 正式版
2008-7-24 网趣网上购物系统时尚版 v8.2
2008-7-24 纵横B2B电子商务系统XYECS!B2B v
2008-7-24 e路小说小偷 v1.2.0723
2008-7-24 凌风美女图片站程序 v2.2
2008-7-24 TOM15电影收索程序
2008-7-24 清风信息自动采集生成系统 v1.0
2008-7-24 QQ邮箱编辑器 v1.0 (小小菜刀ASP
2008-7-19 UltraEdit 简体中文增强版 14.10
2008-7-19 CentOS 5.2 i386 LiveCD
2008-7-19 Snapture多功能相机 v1.4
2008-7-19 iAcces中文输入法 v1.0Build016
2008-7-19 Cookbook烹饪秘籍 v2.5
2008-7-19 苹果专用DVD转换工具 v1.1.59汉化
2008-7-19 Modem修复软件ZiPhone修改版04.0
2008-7-19 AgileMessenger即时通讯工具美化
2008-7-19 Sketches画图软件 v0.7b6破解版


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵