Oracle 数据文件 reuse 属性 说明(转载)
Oracle 表空间 创建参数 说明
http://blog.csdn.net/tianlesoftware/archive/2011/01/27/6166928.aspx
当我们对表空间添加数据文件的时候,有一个reuse 属性。 10g的官网对这个参数的说明如下:
REUSE
Specify REUSE to allow Oracle to reuse an existing file.
(1)If the file already exists, then Oracle reuses the filename and applies the new size (if you specify SIZE) or retains the original size.
--如果file 已经存在,并且在创建时指定了file size,那么就重用原文件,并应用新的size,如果没有指定file size,则保留原有的大小。
(2)If the file does not exist, then Oracle ignores this clause and creates the file.
-- 如果file 不存在,oracle 将忽略该参数。
Restriction on the REUSE Clause
You cannot specify REUSE unless you have specified filename.
Whenever Oracle uses an existing file, the previous contents of the file are lost.
-- 如果Oracle 使用了已经存在的file,那么之前file里的数据将全部丢失。
From:
http://download.oracle.com/docs/cd/B19306_01/server.102/b14200/clauses004.htm#SQLRF01602
在Oracle 11g的官方文档里没有搜到相关的信息。 因为手头还没有11g的库,所以也不好测试。 这篇blog里测试的是基于Oracle 10g环境。
下面我们来做一些测试:
1. 创建一个表空间Dave
SQL> show user;
USER is "SYS"
SQL> create tablespace dave datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' size 100M;
Tablespace created.
2. 创建表anqing,并指定存储表空间dave
SQL> create table anqing tablespace dave as select * from dba_objects;
Table created.
SQL> commit;
Commit complete.
SQL> select count(*) from anqing;
COUNT(*)
----------
50391
SQL> set wrap off;
SQL> select owner,table_name,tablespace_name from dba_tables where table_name='ANQING';
OWNER TABLE_NAME TABLESPACE_NAME
------------------------------ ------------------------------ ------------------
SYS ANQING DAVE
3. 对表空间dave 添加一个新的数据文件,并使用reuse
SQL> alter tablespace dave add datafile '/u01/app/oracle/oradata/dave2/dave02.dbf' reuse;
alter tablespace dave add datafile '/u01/app/oracle/oradata/dave2/dave02.dbf' reuse
*
ERROR at line 1:
ORA-01119: error in creating database file '/u01/app/oracle/oradata/dave2/dave02.dbf'
ORA-17610: file '/u01/app/oracle/oradata/dave2/dave02.dbf' does not exist and no size specified ORA-27037: unable to obtain file status Linux Error: 2: No such file or directory Additional information: 3
-- 这种情况下,如果文件存在,会使用原始文件的大小。但dave02.dbf 不存在,我们又没有指定文件大小,所以无法创建。 我们指定size 就可以创建了。
SQL> alter tablespace dave add datafile '/u01/app/oracle/oradata/dave2/dave02.dbf' size 50M reuse;
Tablespace altered.
SQL>
4. 保持表空间的状态,然后使用reuse 来添加数据文件
SQL> alter tablespace dave add datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' size 50M reuse;
alter tablespace dave add datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' size 50M reuse
*
ERROR at line 1:
ORA-01537: cannot add file '/u01/app/oracle/oradata/dave2/dave01.dbf' - file already part of database
--报错,所以即使我们需要使用reuse,前提也是该数据文件已经不存在该表空间了。
5. 先将datafile offline drop,在reuse
offline drop 并不会drop datafile,仅仅是将datafile 标记为offline,我们online 之后还可以recover回来。 具体参考:
alter database datafile offline drop 与 alter tablespace drop datafile 区别
http://blog.csdn.net/tianlesoftware/archive/2011/04/06/6305600.aspx
SQL> alter database datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' offline drop;
Database altered.
SQL> alter tablespace dave add datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' size 50M reuse;
alter tablespace dave add datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' size 50M reuse
*
ERROR at line 1:
ORA-01537: cannot add file '/u01/app/oracle/oradata/dave2/dave01.dbf' - file already part of database
-- 依旧报错,因为此时数据文件dave01.dbf 的信息还记录在数据字典里。
-- 将数据文件还原回来
SQL> alter database datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' online;
alter database datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' online
*
ERROR at line 1:
ORA-01113: file 6 needs media recovery
ORA-01110: data file 6: '/u01/app/oracle/oradata/dave2/dave01.dbf'
SQL> recover datafile 6;
Media recovery complete.
6. 使用alter tablespace dave drop datafile 命令
该命令在删除控制文件和物理文件,所以没有可用的意义。
SQL> alter tablespace dave drop datafile '/u01/app/oracle/oradata/dave2/dave02.dbf';
Tablespace altered.
[oracle@db2 dave2]$ pwd
/u01/app/oracle/oradata/dave2
[oracle@db2 dave2]$ ls
control01.ctl control03.ctl example01.dbf redo01.log redo03.log system01.dbf undotbs01.dbf
control02.ctl dave01.dbf huaining01.dbf redo02.log sysaux01.dbf temp01.dbf users01.dbf
-- 文件已经不存在
7. 删除表空间后,在reuse
命令如下:
SQL>drop tablespace dave including contents and datafiles;
该命令也可以指定同时删除物理文件,但那样我们的测试就没办法完成,所以我们不删除datafile,仅从控制文件里删除表空间。
SQL> drop tablespace dave including contents;
Tablespace dropped.
SQL> create tablespace dave2 datafile '/u01/app/oracle/oradata/dave2/dave01.dbf' size 50M reuse;
Tablespace created.
-- 重用成功
看一下数据文件大小:
[oracle@db2 dave2]$ ll -h dave01.dbf
-rw-r----- 1 oracle oinstall 51M Jun 3 04:31 dave01.dbf
我们之前是100M,现在变成50M了。
Oracle 数据文件 reuse 属性 说明(转载)的更多相关文章
- Oracle DBA的神器: PRM恢复工具,可脱离Oracle软件运行,直接读取Oracle数据文件中的数据
Oracle DBA的神器: PRM恢复工具,可脱离Oracle软件运行,直接读取Oracle数据文件中的数据 PRM 全称为ParnassusData Recovery Manager ,由 诗檀软 ...
- 收缩Oracle数据文件
最近有网友提到收缩Oracle数据文件的问题,这是DBA经常碰到的一个常见问题.通常我们需要收缩相应的数据文件以减少来自磁盘空间的压力以及提高数据库的整体性能.但这并非对于所有情形都是适用的,尤其是生 ...
- oracle数据文件不小心被删除,导致对应的表空间删不掉的处理方法
问题现象:数据文件被无意删除,导致数据库表空间无法删除,并且重新刷表空间提示表空间已经存在:解决方法:1.oracle用户登录服务器,使用sysdba连接数据库 >sqlplus / as sy ...
- Oracle数据文件在open状态被删除的恢复记录
1.查看当前状态: SQL> select status from v$instance; STATUS------------OPEN SQL> show parameter name; ...
- 批量迁移Oracle数据文件,日志文件及控制文件
有些时候需要将Oracle的多个数据文件以及日志文件重定位或者迁移到新的分区或新的位置,比如磁盘空间不足,或因为特殊需求.对于这种情形可以采取批量迁移的方式将多个数据文件或者日志文件实现一次性迁移.当 ...
- 数据文件个数大于1024时ORACLE数据文件FILE_ID及RELATIVE_FNO的变化示例
通过ROWID计算数据块的相关信息: --详见: 数据文件头块保留大小.ROWID.数据文件最大大小等数据库限制的说明 根据small file tablespace的ROWID,计算出表空间.数据 ...
- Oracle数据文件丢失,数据库如何打开或恢复
(一)如果没有备份只能是删除这个数据文件了,会导致相应的数据丢失.SQL>startup mount--ARCHIVELOG模式命令SQL>Alter database datafile ...
- Oracle 数据文件迁移
背景 这两天做一个oracle数据库迁移,以前都是用exp.imp来走,这次用到了expdp.impdp,的确有些优势,但同时又想起了只是拷贝数据文件迁移的方式,其实这个方式不常用做迁移,更多用在磁盘 ...
- oracle数据文件迁移
这篇文章是从网络上获取的,然后根据内容一步步操作, 1.目前的疑问:移动日志文件的时候,为何要先进行切换? 2.move操作后,再进行rename操作的原理 --------------------- ...
随机推荐
- Java 中关键字transient引出序列化与反序列化
一:transient(临时的)关键字 1.transient关键字只能修饰变量,而不能修饰方法和类.注意,本地变量是不能被transient关键字修饰的. 2.被transient关键字修饰的变量不 ...
- Python之路第二天,基础(2)-基本数据类型
一.Python数据类型 数 在Python中有4种类型的数,整数,长整数,浮点数和复数. 2是一个整数的例子 长整数不过是大一点的整数 3.23和52.3E是浮点数的例子.E标记表示10的幂.52. ...
- 爬虫框架YayCrawler
爬虫框架YayCrawler 各位好!从今天起,我将用几个篇幅的文字向大家介绍一下我的一个开源作品——YayCrawler,其在GitHub上的网址是:https://github.com/liush ...
- Linux下使用sendmail发送邮件
现在每天需要将统计数据发送给指定的人员. 使用原始手工的方式每天发送很麻烦,于是想改成一个定时任务,让服务器自动发送. 技术告诉我说他有写过sendmail的一个脚本. 我尝试使用了一下,发现 ser ...
- BZOJ 2007 海拔
http://www.lydsy.com/JudgeOnline/problem.php?id=2007 思路: 显然海拔是一片0,另一片1,答案就是01的分界线的流量. 本题中的图是平面图,所以求最 ...
- BZOJ 1977 次小生成树(最近公共祖先)
题意:求一棵树的严格次小生成树,即权值严格大于最小生成树且权值最小的生成树. 先求最小生成树,对于每个不在树中的边,取两点间路径的信息,如果这条边的权值等于路径中的权值最大值,那就删掉路径中的次大值, ...
- Sql Server 面试题
1.用一条SQL语句 查询出每门课都大于80分的学生姓名 name kecheng fenshu 张三 语文 81张三 数学 75李四 语文 ...
- Raspberrypi安装使用开发简要说明
Raspberrypi安装使用开发简要说明 (更新于2013年8月25日 newsuppy) 一,安装 使用win32diskimager将操作系统的image刷在SD卡上,image文件可以在htt ...
- HTML5学习笔记简明版 目录索引
http://www.cnblogs.com/TomXu/archive/2011/12/06/2277499.html
- LVM(1)
DM: DM: Device Mapper 逻辑设备 RAID, LVM2 DM: LVM2 快照 多路径