oracle删除表后怎么清理磁盘空间(Oracle 删除用户和表空间详细介绍)
类别:数据库 浏览量:1765
时间:2022-03-28 01:26:23 oracle删除表后怎么清理磁盘空间
Oracle 删除用户和表空间详细介绍Oracle 删除用户和表空间
Oracle 使用时间长了, 新增了许多user 和tablespace. 需要清理一下
对于单个user和tablespace 来说, 可以使用如下命令来完成。
步骤一: 删除user
drop user ×× cascade
说明: 删除了user,只是删除了该user下的schema objects,是不会删除相应的tablespace的。
步骤二: 删除tablespace
DROP TABLESPACE tablespace_name INCLUDING CONTENTS AND DATAFILES;
但是,因为是供开发环境来使用的db, 需要清理的user 和 table space 很多。
思路:
Export出DB中所有的user和tablespace, 筛选出系统的和有用的tablespace,把有用的信息load到一张表中去。然后写例程循环,把不在有用表的tablespace删掉
1. select username,default_tablespace from dba_users;
2.
create table MTUSEFULSPACE ( ID Number(4) NOT NULL PRIMARY KEY, USERNAME varchar2(30), TABLESPACENAME varchar2(60), OWNERNAME varchar2(30) );
3.
declare icount number(2); tempspace varchar2(60); begin for curTable in (select username as allusr,default_tablespace as alltblspace from dba_users) loop tempspace :=curTable.alltblspace; dbms_output.put_line(tempspace); select count(TABLESPACENAME) into icount from MTUSEFULSPACE where TABLESPACENAME = tempspace; if icount=0 then DROP TABLESPACE tempspace INCLUDING CONTENTS AND DATAFILES; end if; commit; end loop; end;
执行后会报如下错误
ORA-06550: 第 10 行, 第 5 列: PLS-00103: 出现符号 "DROP"在需要下列之一时: begin case declare exit for goto if loop mod null pragma raise return select update while with <an identifier> <a double-quoted delimited-identifier> <a bind variable> << close current delete fetch lock insert open rollback savepoint set sql execute commit forall merge pipe 06550. 00000 - "line %s, column %s:\n%s" *Cause: Usually a PL/SQL compilation error. *Action:
好像是被锁了。。
没办法,例程不能写,就只能组出语句执行了。
把需要删除的user, tablespace 导出到Excel. 使用CONCATENATE 组出SQL.
贴到SQLdevelop 批量执行。
整个删除会比较耗时间, 100多个user. 用了12个小时左右。
如要找datafile的具体位置,可以使用
select t1.name,t2.name from v$tablespace t1, v$datafile t2 where t1.ts# = t2.ts#;
SQL code
--删除空的表空间,但是不包含物理文件
drop tablespace tablespace_name;
--删除非空表空间,但是不包含物理文件
drop tablespace tablespace_name including contents;
--删除空表空间,包含物理文件
drop tablespace tablespace_name including datafiles;
--删除非空表空间,包含物理文件
drop tablespace tablespace_name including contents and datafiles;
--如果其他表空间中的表有外键等约束关联到了本表空间中的表的字段,就要加上CASCADE CONSTRAINTS
drop tablespace tablespace_name including contents and datafiles CASCADE CONSTRAINTS;
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣
- oraclemysql知识点(详解Mysql和Oracle之间的误区)
- mysql与oracle体系结构(详解MySQL实时同步到Oracle解决方案)
- docker部署oracle(Docker安装Oracle_11g的方法)
- Oracle TO_CHAR的使用
- mysql的事务隔离级别怎么实现(mysql、oracle默认事务隔离级别的说明)
- mac使用docker部署项目(如何在mac上用docker对Oracle进行部署使用)
- MySQL与Oracle数据类型对应关系
- mysql数据库与表的基本操作总结(Mysql、Oracle中常用的多表修改语句总结)
- Oracle正则表达式的用法
- oracle恢复删除的表数据
- SQL Server与Oracle数据类型的对应关系
- zabbix怎么监控数据库(使用zabbix监控oracle表空间的操作流程)
- zabbix支持oracleodbc功能吗(使用zabbix监控oracle数据库的方法详解)
- php连接oracle(PHP远程连接oracle数据库操作实现方法图文详解)
- oracle中decode函数
- oracle中varchar2(byte)、varchar2(char)、nvarchar2()区别
- 缅甸旅游攻略(缅甸旅游攻略必去景点推荐)
- 《庆余年2》新消息,原班人马,肖战特别出演,这才是最好的安排(庆余年2新消息原班人马)
- 宁夏灵武恐龙化石发现始末(宁夏灵武恐龙化石发现始末)
- 到了岁末 临门一脚 节点,天台综合督评会目标直指 全年红(到了岁末临门一脚)
- 寒假余额不满24小时,不如来一场说走就走的亲子阅读之旅(寒假余额不满24小时)
- 省委书记出席的交流会,十位县委书记同场发言,代表公文材料的高水平(省委书记出席的交流会)
热门推荐
- php在没有命名空间之前是怎么调(php命名空间设计思想、用法与缺点分析)
- pythonturtle库画图代码(用Python中的turtle模块画图两只小羊方法)
- SqlParameter用法
- 使用RouteDebugger对MVC路由进行调试
- html5添加背景(Html5实现首页动态视频背景的示例代码)
- nginx代理docker容器(Docker Nginx容器制作部署实现方法)
- python模块学习之random模块(详解Python基础random模块随机数的生成)
- vue代码和element用法(Vue Element前端应用开发之整合ABP框架的前端登录)
- jquery实现微信中长按识别二维码
- nginx动态路径配置(Nginx本地目录映射实现代码实例)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9