在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

如何解决Oracle调整表空间大小ORA

141次阅读
没有评论

共计 2619 个字符,预计需要花费 7 分钟才能阅读完成。

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

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


from dba_data_files d,dba_free_space f


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


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


from dba_extents


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 错误问题”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-24发表,共计2619字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 亚亚洲乱码一二三四区 | 欧美亚洲国产日韩一区二区三区 | 久久久久久久久影院 | 草草线禁成18年在线视频 | 久久综合久久鬼色 | 日本大片在线观看免费视频 | 一级毛片a免费播放王色 | 韩国av片永久免费 | 国产91精品一区二区视色 | 中字幕久久久人妻熟女天美传媒 | 中文字幕精品视频在线观看 | 免费a级毛片无码视频 | 人妻无码中文专区久久五月婷 | 亚拍精品一区二区三区 | 久久久久久久性 | 午夜久久久久久亚洲国产精品 | 亚洲国产精品无码久久电影 | 欧美老妇与禽交 | 国产九九视频在线观看 | 色综合av男人的天堂伊人 | 极品少妇被猛的白浆直喷白浆 | 久久久久女人精品毛片 | 国产精品白丝久久av网站 | 亚洲av无码av制服丝袜在线 | 特级黄国产片一级视频播放 | 国产69精品久久久久9牛牛 | 福利100合集 在线播放 | 成人欧美一级毛片免费观看 | 免费无码黄十八禁网站在线观看 | 中文字幕在线观看一区二区三区 | 亚洲国产精品一区二区成人片 | 曰韩无码av一区二区免费 | 亚洲欧美一区二区成人片 | 亚洲乱码中文字幕久久孕妇黑人 | 国产初高中生视频在线观看 | 精品久久久久久亚洲精品 | 97久久国产一区二区三区四区 | 国产精品国产三级国产aⅴ下载 | 日本久久精品免视看国产成人 | 色就色欧美 | 久久99国产精品亚洲 |