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;
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
您可能感兴趣
- oracle中decode函数
- SQL Server与Oracle数据类型的对应关系
- Oracle TO_CHAR的使用
- oracle恢复删除的表数据
- zabbix怎么监控数据库(使用zabbix监控oracle表空间的操作流程)
- MySQL与Oracle数据类型对应关系
- Oracle正则表达式的用法
- 安装SQL Server 2016出错提示:需要安装oracle JRE7 更新 51(64位)或更高版本问题的解(安装SQL Server 2016出错提示:需要安装oracle JRE7 更新 5164位或更高版本问题的解)
- oracle中varchar2(byte)、varchar2(char)、nvarchar2()区别
- mysql的事务隔离级别怎么实现(mysql、oracle默认事务隔离级别的说明)
- docker部署oracle(Docker安装Oracle_11g的方法)
- 自己在做项目过程中的php知识(PHP+Oracle本地开发环境搭建方法详解)
- oracle RMAN CONFIGURE配置项
- oracle如何用脚本文件创建表空间(MySQL版oracle下scott用户建表语句实例)
- mysql与oracle如何直接连接(Oracle更换为MySQL遇到的问题及解决)
- oracle和mysql查询所有表(Oracle、MySQL和SqlServe三种数据库分页查询语句的区别介绍)
- 泰国安全吗(泰国安全吗2023)
- 菲律宾安全吗(菲律宾安全吗)
- 泰国旅游攻略(泰国旅游攻略必去景点)
- 数字藏品市场有多乱 周杰伦丢了 一只猴 ,损失超300万(数字藏品市场有多乱)
- 这里输入关键词(怎么输入关键词搜索)
- 得这个 难治病 的人太多了,300个人赶到杭州商量怎么办(得这个难治病的人太多了)
热门推荐
- vue购物车简单项目(vue实现简单购物车案例)
- 在windows安装docker详细步骤(Docker 部署 Prometheus的安装详细教程)
- ubuntu20.2安装mysql(Ubuntu 14.04下mysql安装配置教程)
- SQL中的CONVERT()函数
- 香港服务器有哪些优势呢(浅谈香港服务器与香港云主机的区别)
- 移除VS项目的TFS版本控制
- mysql学习之索引介绍及其原理(MySQL学习教程之聚簇索引)
- php数组取值方法(php给数组赋值的实例方法)
- docker容器内部怎么查看id(docker容器中无法获取宿主机hostname的解决方案)
- python爬虫模块教程(Python爬虫之UserAgent的使用实例)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9