广告
返回顶部
首页 > 资讯 > 数据库 >如何解决Oracle调整表空间大小ORA-03297错误问题
  • 896
分享到

如何解决Oracle调整表空间大小ORA-03297错误问题

2024-04-02 19:04:59 896人浏览 薄情痞子
摘要

这篇文章给大家分享的是有关如何解决oracle调整表空间大小ORA-03297错误问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Oracle调整表空间大小—ORA-03297

这篇文章给大家分享的是有关如何解决oracle调整表空间大小ORA-03297错误问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

Oracle调整表空间大小—ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

将备份的一个大数据库还原到本机以后,删除里面的大表(比如文件表、日志表等),Oracle数据文件在有数据的情况下能自动扩展,却不能自动收缩,造成存储空间的浪费。
起源于我删除了database里的一个大表造成很多空间浪费,想回收空间
如果直接修改数据文件的大小,可能会遇到如下错误:ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

转载网址:Http://blog.sina.com.cn/s/blog_54eeb5d901000bvg.html

sql> ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300m;
ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300m
*
ERROR 位于第 1 行:
ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据

但是

SQL>select d.file_name,d.file_id,d.bytes/1024/1024 as d_byte,sum(f.bytes/1024/1024) as free_byte

2   from dba_data_files d,dba_free_space f

3   where d.file_id=f.file_id and d.file_id=18

4   group by d.file_name,d.file_id,d.bytes/1024/1024;

FILE_NAME                             FILE_ID    D_BYTE    FREE_BYTE

---------------------------------    ---------- ---------- ----------

D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA     18       1536     1482.0625

可以看到实际上ID=18的文件只使用了大概50M左右,只是数据分布在(按一定的顺序)50M甚至在300M以外的地方,所以这里虽然看到只使用了约50M空间,但是却不能resize datafile.

为此,要改小数据文件,我们先要对文件上的表和索引移动一下位置,具体做法如下:

 1、移动表前先对表空间做整理

SQL>alter tablespace ic_data coalesce;

 2、在dba_extents找到与ID=18的数据文件相关的表及索引

SQL>select segment_name,partition_name,segment_type

2   from dba_extents

3   where file_id=18;

 3、对id=18的文件上的表和索引移动位置

SQL> set heading off
SQL> set echo off
SQL> set feedback off
SQL> set termout on
SQL> spool d:\aaa.sql

//移动表

SQL>select DISTINCT 'alter table '|| segment_name || ' move tablespace test_space;' from dba_extents where segment_type='TABLE' and file_id=18;

//移动索引

SQL>select DISTINCT 'alter index '|| segment_name || ' rebuild tablespace test_space;' from dba_extents where segment_type='INDEX' and file_id=18;

//移动分区表

SQL>select DISTINCT 'alter table '|| segment_name || ' move partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='TABLE PARTITION' and file_id=18;

//移动分区索引

SQL>select DISTINCT 'alter index '|| segment_name || ' rebuild partition '|| partition_name || ' tablespace test_space;' from dba_extents where segment_type='INDEX PARTITION' and file_id=18;

SQL>spool off 

然后执行aaa.sql,注意保证test_space有足够的空间容纳这些数据,

先要新建test_space空间,把数据移动到新表空间中,缩小原表空间,将数据移动回原表空间,删除test_space空间

其实可以不移动所有的数据,但是总的测验是不是移动了300M以外的数据,所以还是移动所有数据的方便

 4这样移动了所有的数据以后就可以对datafile resize了

SQL>  ALTER DATABASE DATAFILE 'D:\ORACLE\ORADATA\ICAPP\IC_DATA6.ORA' RESIZE 300M
数据库已更改。

 5把原来表空间ic_data中的数据再移动回来,修改aaa.sql中的表空间名为ic_data再执行,然后drop tablespace test_space including contents and datafiles。

-----------------------分割线-----------------------------分割线-----------------------------分割线----------------------------

经过实践,以上方法可以处理ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据问题。

但是如果一个表空间被多个Oracle用户使用,在导出sql文件时要指定用户,否则在执行sql文件时会报错。

 感谢各位的阅读!关于“如何解决Oracle调整表空间大小ORA-03297错误问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

您可能感兴趣的文档:

--结束END--

本文标题: 如何解决Oracle调整表空间大小ORA-03297错误问题

本文链接: https://www.lsjlt.com/news/64306.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何解决Oracle调整表空间大小ORA-03297错误问题
    这篇文章给大家分享的是有关如何解决Oracle调整表空间大小ORA-03297错误问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Oracle调整表空间大小—ORA-03297...
    99+
    2022-10-18
  • Oracle缩表空间问题如何解决
    这篇文章主要介绍“Oracle缩表空间问题如何解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Oracle缩表空间问题如何解决”文章能帮助大家解决问题。备注:Oracle 11.2.0.4一. 需...
    99+
    2023-07-02
  • 如何解决Oracle数据库ORA-12560错误问题
    这篇文章主要为大家展示了如何解决Oracle数据库ORA-12560错误问题,内容简而易懂,希望大家可以学习一下,学习完之后肯定会有收获的,下面让小编带大家一起来看看吧。官网中关于ORA-12560的解释:...
    99+
    2022-10-18
  • Win7如何调整DPI以解决间距不同内容有大有小问题
      如今电脑的显示屏越做越大,分辨率也是越来越高,这意味着人们对视觉享受的要求更上一层楼,平时我们会调节分辨率来感受电脑屏幕的细腻,这招对于查看图片或视频是有用的,但是如果是阅读文字呢由于文字间的间距不同,文本内容有大有...
    99+
    2023-06-12
    Win7 DPI 间距 内容 问题
  • 如何解决linux系统CentOS下调整home和根分区大小的问题
    这篇文章主要介绍“如何解决linux系统CentOS下调整home和根分区大小的问题”,在日常操作中,相信很多人在如何解决linux系统CentOS下调整home和根分区大小的问题问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法...
    99+
    2023-06-10
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作