`
黑暗天使
  • 浏览: 94949 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

删除表空间的操作

 
阅读更多

删除表空间的操作

一个用户要删除数据库的表空间,首先该用户要具备drop tablespace的权限

在当前用户下执行以下语句来查询确认

select a2.username,a1.privilege from dba_sys_privs a1 , user_role_privs a2
where a1.privilege = 'DROP TABLESPACE'
and a1.grantee =a2.granted_role


SQL> conn xxx/xxx
已连接。
SQL> select a2.username,a1.privilege from dba_sys_privs a1 , user_role_privs a2
2 where a1.privilege = 'DROP TABLESPACE'
3 and a1.grantee =a2.granted_role;

USERNAME                       PRIVILEGE
------------------------------ ----------------------------------------
WULW                           DROP TABLESPACE

如果没有 drop tablespace,请先用更高级的用户(如sys)给予授权

SQL> conn sys/oracle@ibm as sysdba;
已连接。
SQL> grant drop tablespace to wulw   ;

授权成功。


以上前提条件确认完,下面开始实验.

确认已有的表空间

SQL> select a.TS# ,a.NAME , b.NAME from v$tablespace a,v$datafile b
2 where a.TS# = b.TS#;

TS# NAME NAME
0 SYSTEM L:\ORACLE\ORADATA\IBM\SYSTEM01.DBF
1 UNDOTBS1 L:\ORACLE\ORADATA\IBM\UNDOTBS01.DBF
3 CWMLITE L:\ORACLE\ORADATA\IBM\CWMLITE01.DBF
4 DRSYS L:\ORACLE\ORADATA\IBM\DRSYS01.DBF
5 EXAMPLE L:\ORACLE\ORADATA\IBM\EXAMPLE01.DBF
6 INDX L:\ORACLE\ORADATA\IBM\INDX01.DBF
7 ODM L:\ORACLE\ORADATA\IBM\ODM01.DBF
8 TOOLS L:\ORACLE\ORADATA\IBM\TOOLS01.DBF
9 USERS L:\ORACLE\ORADATA\IBM\USERS01.DBF
10 XDB L:\ORACLE\ORADATA\IBM\XDB01.DBF
12 TDATA_01 L:\ORACLE\ORADATA\IBM\TDATA_01.ORA
14 TINDEX_01 L:\ORACLE\ORADATA\IBM\TINDEX_01.ORA

已选择12行。(为看起来直观,上面的显示作了手工格式化)

创建新的测试表空间:

SQL> create tablespace mytbs01
2 logging
3 datafile 'L:\ORACLE\ORADATA\IBM\mytbs01.dbf' size 10m REUSE ;

表空间已创建。

SQL> CREATE TABLESPACE "MYTBS02" 
2      LOGGING 
3      DATAFILE 'L:\ORACLE\ORADATA\IBM\MYTBS02.dbf' SIZE 10M REUSE ;

表空间已创建。

如果表空间里面没有任何数据对象,可以直接删除.


SQL> drop tablespace mytbs01;

表空间已丢弃。

这种删除方式相关的数据文件仍然存在于磁盘上.

(可以进入数据文件所在目录L:\ORACLE\ORADATA\IBM 进行查看 MYTBS01.DBF )


如果表空间里面含有数据对象,那么该表空间就不能像上面那样做直接删除了.


SQL> create tablespace mytbs01
2 logging
3 datafile 'L:\ORACLE\ORADATA\IBM\mytbs01.dbf' size 10m REUSE;

表空间已创建。

SQL> create table test(mobile number(13))
2 tablespace mytbs01;

表已创建。

SQL> drop tablespace mytbs01;
drop tablespace mytbs01
*
ERROR 位于第 1 行:
ORA-01549: 表空间非空,请使用 INCLUDING CONTENTS 选项

看到了吧,提示ora-01549错误.

如果要删除该表空间,可加上including contents子句.

如: drop tablespace mytbs01 including contents ;

如果想在删除表空间的同事也删除掉对应的数据文件,那就在上面的语句最后加上 and datafiles

成为 drop tablespace mytbs01
including contents and datafiles;


SQL> drop tablespace mytbs01
2 including contents and datafiles;

表空间已丢弃。

要注意的一点是,如果drop tablespace语句中含有datafiles,那datafiles之前必须有contents关键字,不然会提示ora-01911错误:


SQL> drop tablespace mytbs02
2 including datafiles; 
including datafiles
           *
ERROR 位于第 2 行:
ORA-01911: 需要 CONTENTS 关键字

接下来的实验是:

如果表空间A中有一个表ta,表空间B中有一个表tb,而ta与tb有着某种关系,那么是否可以按上面的方法直接干掉表空间A和表空间B呢?

看试验过程:


SQL> create tablespace mytbs01
2 logging
3 datafile 'L:\ORACLE\ORADATA\IBM\mytbs01.dbf' size 10m REUSE;

表空间已创建。

SQL> CREATE TABLESPACE "MYTBS02" 
2      LOGGING 
3      DATAFILE 'L:\ORACLE\ORADATA\IBM\MYTBS02.dbf' SIZE 10M REUSE ;
CREATE TABLESPACE "MYTBS02"
*
ERROR 位于第 1 行:
ORA-01543: 表空间 'MYTBS02' 已经存在


SQL> create table test(mobile number(13))
2 tablespace mytbs01;

表已创建。

SQL> create table test2(mobile number(13))
2 tablespace mytbs02;

表已创建。

SQL> alter table TEST2
2    add primary key (mobile);

表已更改。

SQL> ALTER   TABLE   test    
2   ADD   CONSTRAINT   FOREIGN con_mobile    REFERENCES   test2(mobile);

表已更改。

以上的意思是:在表空间mytbs01上创建表test,在表空间mytbs02上创建表test2,两个表test和test2以外键相关联,test2为主表,test为从表.

现在尝试能否用上面的语句直接干掉mytbs02:


SQL> drop tablespace mytbs02;
drop tablespace mytbs02
*
ERROR 位于第 1 行:
ORA-01549: 表空间非空,请使用 INCLUDING CONTENTS 选项


SQL> drop tablespace mytbs02
2 including contents;
drop tablespace mytbs02
*
ERROR 位于第 1 行:
ORA-02449: 表中的唯一/主键被外部关键字引用


SQL> drop tablespace mytbs02
2 including contents and datafiles;
drop tablespace mytbs02
*
ERROR 位于第 1 行:
ORA-02449: 表中的唯一/主键被外部关键字引用

可见主表所在表空间因为表与其他空间上的表有联系,所以没办法直接删掉.


那mytbs01表空间能不能干掉?请看:

SQL> drop tablespace mytbs01
2 including contents and datafiles;

表空间已丢弃。

SQL> drop tablespace mytbs02
2 including contents and datafiles ;

表空间已丢弃。


嘿嘿,从表test所在的表空间mytbs01能直接干掉,而且从表的表空间干掉后,主表test2所在的表空间mytbs02也能干掉了!

那么,如果我只想干掉主表所在的表空间,又不想干掉从表所在的表空间那怎么办?

很简单,最笨的一招就是想把两个表的关联关系给灭了,(在上面的两个表中,就是把那个外键给删了)再把主表表所在的表空间删了.但这种方法可不太现实,如果一个表空间里有成百上千个对象与别的表空间里的对象有联系,总不能一个一个去"解铃"吧? 即使你本人就是"系铃"人,估计你也要"解"到郁闷死!

一个更简单的方法当然是级联删除了!

drop tablespace mytbs02
including contents and datafiles cascade constraints

试验如下:


SQL> create tablespace mytbs01
2 logging
3 datafile 'L:\ORACLE\ORADATA\IBM\mytbs01.dbf' size 10m REUSE;

表空间已创建。

SQL> CREATE TABLESPACE "MYTBS02" 
2      LOGGING 
3      DATAFILE 'L:\ORACLE\ORADATA\IBM\MYTBS02.dbf' SIZE 10M REUSE ;

表空间已创建。

SQL> create table test(mobile number(13))
2 tablespace mytbs01;

表已创建。

SQL> create table test2(mobile number(13))
2 tablespace mytbs02;

表已创建。

SQL> alter table TEST2
2    add primary key (mobile);

表已更改。

SQL> ALTER   TABLE   test    
2   ADD   CONSTRAINT   FOREIGN con_mobile    REFERENCES   test2(mobile);

表已更改。

SQL> drop tablespace mytbs02
2 including contents and datafiles cascade constraints;

表空间已丢弃。


OK!正常搞定!

分享到:
评论

相关推荐

    如何正确的删除Oracle表空间数据文件

    在Oracle数据库管理中,删除表空间数据文件是一项关键操作,涉及到数据的安全性和系统的稳定性。本文将详细介绍如何正确地删除Oracle表空间数据文件,探讨OFFLINE和OFFLINE DROP的区别,以及在操作系统层面删除数据...

    oracle定时删除表空间的数据并释放表空间

    3. **purge操作**:Purge操作是删除已删除行的一种方法,通常用于临时表空间和Undo表空间。执行`PURGE`语句可以立即释放被删除的对象或行,而不是等待下次DML操作或数据库维护任务。 4. **DBMS_SCHEDULE包**:...

    oracle快速删除表空间

    删除表空间是一项严肃的操作,因为它不仅会影响到表空间内的所有对象,还可能对数据库的整体性能产生影响。 1. **准备工作** 在删除表空间之前,你需要确保该表空间内没有任何活动的对象。这包括检查是否有正在运行...

    oracle创建表空间和用户授权及删除表空间和用户

    在Oracle数据库管理中,创建与删除表空间以及用户授权是非常重要的操作。本文将详细介绍如何在Oracle环境下进行这些操作,包括创建表空间、为用户分配权限、以及如何删除表空间和用户。 ### 一、创建表空间 #### ...

    oracle误删除表空间后恢复

    由于误删除表空间需要system表空间中的信息,因此首先需要恢复system表空间到删除操作之前的版本。这通常通过RMAN的恢复命令实现,例如`RESTORE DATAFILE 1;`,其中1是system表空间对应的数据文件编号。恢复完成后,...

    建立/删除orcale表空间 和用户 sql

    在压缩包中的文件`表空间操作.sql`、`sql_创建表空间.sql`和`sql_删除表空间.sql`可能包含了具体的示例脚本,供你参考和实践这些操作。请根据实际需求进行修改和执行,以确保数据库的管理和组织符合你的业务需求。...

    oracle表空间操作详解

    Oracle 表空间操作详解 Oracle 表空间操作详解是数据库管理员在设计和管理 Oracle 数据库时的一项重要任务。通过表空间,可以控制用户对磁盘空间的使用,限制用户可以使用的磁盘空间大小,避免硬盘空间耗竭。 一、...

    ORACLE_表空间操作(图)

    本文将深入解析Oracle表空间的操作,包括通过图形界面和SQL命令进行的创建、修改和删除过程。 ### 创建表空间 #### 图形界面创建表空间 在Oracle数据库的企业管理控制台中,可以通过以下步骤创建一个新的表空间:...

    删除表空间

    当需要彻底删除一个已创建的或错误的表空间时,需要遵循一定的步骤,因为这涉及到数据库的数据安全性和完整性。下面将详细解释如何在PL/SQL环境中进行这个操作,并解决可能遇到的问题。 首先,我们遇到的问题是无法...

    Oracle数据库用户角色、表空间创建、删除命令

    ### Oracle数据库用户角色、表空间创建与删除命令详解 #### 创建数据表空间 在Oracle数据库中,表空间是逻辑存储单元,它由一个或多个数据文件组成,用于存储数据库对象,例如表、索引等。要创建一个新的数据表...

    表空间文件被误删除 怎么办

    8. **预防措施**:为避免类似问题再次发生,应强化数据保护策略,包括定期备份、严格的文件操作权限管理、使用文件系统级别的删除保护,并对重要表空间进行额外的冗余配置。 9. **数据库监控**:设置数据库健康监控...

    学习oracle创建一个表空间创建临时表空间创建用户表空间资源的权限

    - **删除表空间**:使用`DROP TABLESPACE`删除表空间,但需注意清理相关对象和依赖关系。 在实际应用中,Oracle数据库管理员还需要考虑表空间的备份、恢复、性能优化等方面的问题。理解并熟练掌握表空间的管理和...

    oracle创建删除表空间和用户授权

    根据提供的文件信息,本文将详细解释Oracle数据库中创建与删除表空间、用户授权以及相关操作的具体步骤和原理。 ### 一、创建与删除表空间 #### 1. 创建临时表空间 ```sql CREATE TEMPORARY TABLESPACE bigoa_temp...

    oracle创建删除表空间和用户授权的一些语句 可以直接使用

    ### Oracle 创建与删除表空间及用户授权操作指南 在Oracle数据库管理中,创建与删除表空间、用户授权等操作是数据库管理员(DBA)经常需要处理的任务。这些操作对于确保数据库资源的有效分配、数据安全性和系统性能...

    删除oracle数据库表空间的办法

    下面将详细介绍如何安全地删除Oracle数据库中的表空间,以及在操作前需要考虑的一些关键点。 1. **确认表空间状态** 在删除表空间之前,必须确保没有任何对象在其中。这包括表、索引、视图、存储过程等。你可以...

    oracle物理表空间删除修复命令

    在日常的数据库操作中,可能会遇到误删除物理表空间的情况,这时就需要采取相应的措施进行恢复。本文将详细介绍如何通过Oracle提供的命令来完成物理表空间的删除以及在误删之后如何进行有效的修复。 #### 二、...

    QQ空间说说批量删除丨2023年最新版批量删除QQ空间说说插件

    批量删除QQ空间说说丨2023年最新版QQ空间说说批量删除插件 2023年最新空间新版批量删除q空间说说代码 QQ空间-plugin 2023批量删除QQ空间说说脚本 2023最新QQ版本界面: 功能包括了 最新QQ支持清空QQ空间说说批量删除...

    Oracle回滚表空间数据文件误删除处理

    Oracle回滚表空间数据文件误删除处理是一个严重的问题,因为它涉及到数据库的核心组件——回滚段。回滚段在Oracle数据库中扮演着至关重要的角色,它们记录了事务的修改历史,确保了数据库的一致性,同时也为数据库...

    Oracle数据库用户角色、表空间创建、删除命令.pdf

    - **如果删除表空间之前删除了表空间文件**: 1. 使用`sqlplus`连接到数据库。 2. 执行`SHUTDOWN ABORT`和`STARTUP MOUNT`。 3. 将已删除的数据文件离线并删除。 4. 最后删除表空间。 以上就是关于Oracle数据库...

    ORACLE 表空间的部分操作

    本文将详细介绍Oracle中关于表空间的一些关键操作,包括创建、修改、管理和删除表空间的过程,以及如何处理表空间的在线与离线状态,数据文件的管理,以及表空间的扩展策略。 #### 一、建立表空间 创建表空间是...

Global site tag (gtag.js) - Google Analytics