文章目录

  • 前言
  • 一、降低表空间高水位
    • 1.查看表空间和对应物理文件名
    • 2.清空回收站
    • 3.整理表空间
    • 4.生成RESIZE代码
  • 二、在删除时进行释放
    • 1.清空表数据并释放表空间
    • 2.迁移表数据
  • 参考文档

前言

在使用Oracle进行录入测试时,我们会制造许多测试数据,而使用删除后表空间的高水位依旧无法自动下调,导致出现表空间出现空白数据,影响表空间性能的同时也占用了过多的存储空间。


一、降低表空间高水位

1.查看表空间和对应物理文件名

代码如下:

select
b.file_id 物理文件号,
b.file_name 物理文件名,
b.tablespace_name 表空间,
b.bytes/1024/1024 大小M,
(b.bytes-sum(nvl(a.bytes,0)))/1024/1024  已使用M,
substr((b.bytes-sum(nvl(a.bytes,0)))/(b.bytes)*100,1,5)  利用率
from dba_free_space a,dba_data_files b
where a.file_id=b.file_id
group by b.tablespace_name,b.file_id,b.file_name,b.bytes
order by b.tablespace_name

根据利用率可以直观的判断有那些表空间可以进行释放。

2.清空回收站

代码如下:

-- 清除用户回收站
purge recyclebin;
-- 清除全库回收站
purge dba_recyclebin;

清除删除过程中遗留的数据。

3.整理表空间

代码如下:

alter tablespace tablespace_name coalesce;

整合表空间的碎片增加表空间的连续性

4.生成RESIZE代码

代码如下:

select a.file#,a.name,a.bytes/1024/1024 CurrentMB,
ceil(HWM * a.block_size)/1024/1024 ResizeTo,
(a.bytes - HWM * a.block_size)/1024/1024 ReleaseMB,
'alter database datafile '''||a.name||''' resize '||
ceil(HWM * a.block_size/1024/1024) || 'M;' ResizeCMD
from v$datafile a,
(select file_id,max(block_id+blocks-1) HWM
from dba_extents where file_id in
(select b.file# From v$tablespace a ,v$datafile b
where a.ts#=b.ts# and a.name='tablespace_name')
group by file_id) b
where a.file# = b.file_id(+)
and (a.bytes - HWM *block_size)>0
order by 5

上述代码执行后,可以生成一个对应表空间RESIZE的SQL代码,此时运行对应的SQL代码即可。

二、在删除时进行释放

1.清空表数据并释放表空间

代码如下:

-- 清空表数据
truncate table table_name;
-- 释放表空间
alter table table_name deallocate UNUSED KEEP 0;

先清空表数据,此时表依旧存在,Truncate不支持回滚,并且不能truncate一个带有外键的表,如果要删除首先要取消外键,然后再删除;
注意如果不加KEEP 0的话,表空间是不会释放的。

2.迁移表数据

在出现以下错误时,我们不仅可以通过整理表空间或者清楚回收站进行解决,还可以通过将待释放表空间的表数据全部迁移到其他表空间,将空间释放后再迁移回原表空间。

 --需移动的表数据select DISTINCT 'alter table '|| owner||'.'||segment_name || ' move tablespace user_test;' from dba_extents where segment_type='TABLE' and file_id=4;--需移动的索引数据select DISTINCT 'alter index '|| owner||'.'|| segment_name || ' rebuild tablespace user_test;' from dba_extents where segment_type='INDEX' and file_id=4;--需移动的分区表数据select DISTINCT 'alter table '|| owner||'.'|| segment_name || ' move partition '|| partition_name || ' tablespace user_test;' from dba_extents where segment_type='TABLE PARTITION' and file_id=4;--需移动的分区表索引数据select DISTINCT 'alter index '|| owner||'.'|| segment_name || ' rebuild partition '|| partition_name || ' tablespace user_test;' from dba_extents where segment_type='INDEX PARTITION' and file_id=4;

上述代码中file_id可以通过查看表空间进行比对更改,上述代码执行后可以获得对应的自动生成的SQL代码,此时运行对应的SQL代码即可迁移表数据


参考文档

Oracle 在删除表、表空间、用户时 如何释放磁盘空间
【Oracle】ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据
Oracle查看表空间数据文件SQL
Oracle 删除数据后释放数据文件所占磁盘空间(表空间降高水位)
oracle 如何查看当前用户的表空间名称
Resize Datafile时ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

先自我介绍一下,小编13年上师交大毕业,曾经在小公司待过,去过华为OPPO等大厂,18年进入阿里,直到现在。深知大多数初中级java工程师,想要升技能,往往是需要自己摸索成长或是报班学习,但对于培训机构动则近万元的学费,着实压力不小。自己不成体系的自学效率很低又漫长,而且容易碰到天花板技术停止不前。因此我收集了一份《java开发全套学习资料》送给大家,初衷也很简单,就是希望帮助到想自学又不知道该从何学起的朋友,同时减轻大家的负担。添加下方名片,即可获取全套学习资料哦

Oracle数据库表空间整理回收与释放操作相关推荐

  1. 更改oracle 表空间大小,更改oracle数据库表空间大小

    Oracle表空间扩展 使用oracle时可能遇到无法通过8192在表空间中扩展错误,原因是数据库的表空间不足. oracle表空间数据文件容量与db_block_size有关,在初始建库时指定DB_ ...

  2. Oracle数据库查看表空间sql语句、查看Oracle数据库表空间剩余 、修改表空间、库备份

    一  Oracle数据库查看表空间sql语句 1.oracle查看表空间当前用户 SQL>  select  username,default_tablespace  from user_use ...

  3. Oracle 数据库表空间不足拓展方法实例演示,表空间剩余大小查看,通过新增表空间文件拓展表空间,表空间文件路径查看

    Oracle 数据库表空间 第一章:表空间的拓展 ① 查看剩余表空间大小 ② 查看表空间文件路径 ③ 通过新增表空间文件拓展表空间 ④ 查看表空间已分配大小 第一章:表空间的拓展 ① 查看剩余表空间大 ...

  4. linux数据库创建表空间语句,如何用LINUX用命令创建ORACLE数据库表空间和用户

    如何用LINUX用命令创建ORACLE数据库表空间和用户 文本模式下如何建 更新时间:2019-06-21 19:36 最满意答案 先su 到 oracle用户,SYS用户以DBA身份登陆 //创建临 ...

  5. 查看Oracle数据库表空间大小(空闲、已使用),是否要增加表空间的数据文件

    http://suan2046.iteye.com/blog/379539 标题:查看Oracle数据库表空间大小,是否需要增加表空间的数据文件 在数据库管理中,磁盘空间不足是DBA都会遇到的问题,问 ...

  6. 创建oracle 数据库表空间,角色,用户的sql语句

    创建oracle 数据库表空间,角色,用户的sql语句 1.创建角色 CREATE ROLE "QIUDINGROLE" NOT IDENTIFIED; GRANT "C ...

  7. 唐老师 oracle,ORACLE数据库表空间的监控和维护_快速发表职称论文网

    ORACLE数据库表空间的监控和维护 摘 要:通过ORACLE数据库内部管理表和视图加强数据库系统数据表空间的监控和维护. 关键字:数据库表空间监控 ORACLE数据库在系统性能,安全性以及可靠性方面 ...

  8. oracle数据库表空间巡检

    shell oracle数据库表空间.进程.监听自动巡检 1.巡检标准 (1)使用oracle用户登录 (2)执行红色字体部分进入数据库:sqlplus "/as sysdba" ...

  9. Oracle数据库表导出和导入csv文件操作

    Oracle数据库表导出和导入csv文件操作 数据库是Oracle 9i 1.导出csv文件 这个十分简单,用pl/sql工具即可,首先选中要导出的表,右键选择Query data,在左侧出现的窗口中 ...

最新文章

  1. 数据绑定(Binding)
  2. mongo实现消息队列
  3. WR:中国46个饮用水供水系统评估水源水对龙头水细菌群落的“烙印”
  4. 使用Charles在iOS6上进行抓包
  5. linux命令pwd
  6. Java mybatis实现mysql批量插入
  7. BODY background=自适应大小_自适应(电脑/平板/手机)网页,自适应网页设计练习总结...
  8. scala特性_Scala | 特性应用
  9. Linux中断(interrupt)子系统之三:中断流控处理层
  10. 计算机双系统,自己在计算机上安装双系统
  11. 腾讯广告算法大赛“视”界杯专题直播来袭,腾讯专家助你赛场争先!
  12. 谷歌更新漏洞披露规则:不管补丁打没打,够90天才披露
  13. ppt生成eps文件_eps是什么格式怎么打开?全面解析图片的eps是什么格式
  14. invalid byte 1 of 1-byte UTF-8 sequence
  15. ERWIN中的一对多标识关系和一对多非标识关系
  16. 编译内核遇到:error: ‘ovl_v1_fs_type’ undeclared (first use in this function)错误
  17. java.lang.IllegalArgumentException: Not an entity: class
  18. 阿龙的学习笔记---Effective C++---第一章:习惯C++
  19. 写c语言时鼠标变成黑色柱体
  20. python中syntaxerror什么意思_在Python中,“SyntaxError:调用'print'时缺少括号”是什么意思?...

热门文章

  1. 主流的开源免费erp(至少十年以上历史)
  2. 打造百亿量级、亿级日活SDK的十大关键要点
  3. 小米max3支持html吗,小米Max3这款手机是否有OTG功能,支持OTG鼠标和U盘吗?
  4. ECharts 实现世界地图
  5. python求两个数的最大公约数穷举法_五十九、如何求N个数的最大公约数和最小公倍数...
  6. ant-design中Input输入框在获取焦点时由于保留了上次输入内容而莫名出现了一个黑色背景的选择提示框,且选择提示框中的值后还会出现蓝色背景
  7. linux红外遥控进程,46.Linux-分析rc红外遥控平台驱动框架,修改内核的NEC解码函数BUG(1)...
  8. 二叉树的遍历 中序线索二叉树
  9. 机器学习算法面经(阿里京东拼多多百度等)
  10. python绘制动态图形_让Python绘制一套动态图形给你看看