用SQL语句删除数据库中的逻辑文件,若数据库的该逻辑文件有信息,是否能删除?

用SQL语句删除数据库中的逻辑文件,若数据库的该逻辑文件有信息,是否能删除?,第1张

没有简单的方法来删除表空间的数据文件,唯一的方法是删除整个定义的表空间,步骤有下面(前提是这个数据文件上的数据是不需要了):因为使用alter database datafile 'name' offline drop,也可以物理的删除一个数据文件但它的信息仍然记录在数据字典中(不影响数据库的运行)。

如果数据库运行在非归档模式:

1. MOUNT数据库 - startup mount

2. 删除数据文件 - alter database datafile xxx offline drop

3. 打开(OPEN)数据库 - alter database open

4. 查看属于该表空间的所有对象:

select owner, segment_name, segment_type

from dba_segments

where tablespace_name='tbs_name'

5. 导出该表空间的所有对象------用exp命令来做

6. 删除表空间 - drop tablespace tbs_name including contents

7. 删除这个表空间的所有物理的数据文件Delete the physical datafiles belonging to the tablespace

8. 重建表空间,导入前面导出的DMP文件.

如果数据库是运行在归档模式:

1. MOUNT数据库 - startup mount

2. 删除数据文件 - alter database datafile xxx offline

(Note: offline这个数据文件,此数据文件还是属于这个数据库的一部分,只是在控制文件中将它的状态标记为offline.)

3. 在 *** 作系统一级删除物理的数据文件

4. 打开(OPEN)数据库 - alter database open

5. 后面的可以做下面 *** 作:

导出该表空间的对象

删除表空间

重建表空间并导入对象

如果数据库运行在归档模式下,并且数据文件有备份:

1.MOUNT数据库

2.OFFLINE数据文件:alter database datafile xxx offline

3.将备份的数据文件拷贝到原来数据文件的位置.

4.将备份数据文件到目前的所有归档日志放到归档目录.

5.恢复数据文件:recover automatic datafile xxx(要输入全路径名)

6.然后ONLINE数据文件:alter database datafile xxx online

7.打开(OPEN)数据库:alter database open

8.做一次数据库的关机全备份.

看导出什么库了,如果导出整个库,需要dba权限,如果只导出当前用户的库就不需要了。

oracle导出说明:

1. 获取帮助

exp help=y

2. 导出一个完整数据库

exp system/manager file=bible_db log=dible_db full=y

3. 导出数据库定义而不导出数据

exp system/manager file=bible_db log=dible_db full=y rows=n

4. 导出一个或一组指定用户所属的全部表、索引和其他对象

exp system/manager file=seapark log=seapark owner=seapark

exp system/manager file=seapark log=seapark owner=(seapark,amy,amyc,harold)

注意:在导出用户时,尽管已经得到了这个用户的所有对象,但是还是不能得到这些对象引用的任何同义词。解决方法是用以下的SQL*Plus命令创建一个脚本文件,运行这个脚本文件可以获得一个重建seapark所属对象的全部公共同义词的可执行脚本,然后在目标数据库上运行该脚本就可重建同义词了。

SET LINESIZE 132

SET PAGESIZE 0

SET TRIMSPOOL ON

SPOOL c:\seapark.syn

SELECT 'Create public synonym '||synonym_name

||' for '||table_owner||'.'||table_name||''

FROM dba_synonyms

WHERE table_owner = 'SEAPARK' AND owner = 'PUBLIC'

SPOOL OFF

5. 导出一个或多个指定表

exp seapark/seapark file=tank log=tank tables=tank

exp system/manager file=tank log=tank tables=seapark.tank

exp system/manager file=tank log=tank tables=(seapark.tank,amy.artist)

6. 估计导出文件的大小

全部表总字节数:

SELECT sum(bytes)

FROM dba_segments

WHERE segment_type = 'TABLE'

seapark用户所属表的总字节数:

SELECT sum(bytes)

FROM dba_segments

WHERE owner = 'SEAPARK'

AND segment_type = 'TABLE'

seapark用户下的aquatic_animal表的字节数:

SELECT sum(bytes)

FROM dba_segments

WHERE owner = 'SEAPARK'

AND segment_type = 'TABLE'

AND segment_name = 'AQUATIC_ANIMAL'

7. 导出表数据的子集(oracle8i以上)

NT系统:

exp system/manager query='Where salad_type='FRUIT'' tables=amy.salad_type

file=fruit log=fruit

UNIX系统:

exp system/manager query=\"Where salad_type=\'FRUIT\'\" tables=amy.salad_type

file=fruit log=fruit

8. 用多个文件分割一个导出文件

exp system/manager

file=(paycheck_1,paycheck_2,paycheck_3,paycheck_4)

log=paycheck, filesize=1G tables=hr.paycheck

9. 使用参数文件

exp system/manager parfile=bible_tables.par

bible_tables.par参数文件:

#Export the sample tables used for the Oracle8i Database Administrator's Bible.

file=bible_tables

log=bible_tables

tables=(

amy.artist

amy.books

seapark.checkup

seapark.items

)

10. 增量导出

“完全”增量导出(complete),即备份整个数据库

exp system/manager inctype=complete file=990702.dmp

“增量型”增量导出(incremental),即备份上一次备份后改变的数据

exp system/manager inctype=incremental file=990702.dmp

“累计型”增量导出(cumulative),即备份上一次“完全”导出之后改变的数据

exp system/manager inctype=cumulative file=990702.dmp


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/9878576.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-02
下一篇 2023-05-02

发表评论

登录后才能评论

评论列表(0条)

保存