91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何解決Oracle調整表空間大小ORA-03297錯誤問題

發布時間:2021-11-10 09:39:59 來源:億速云 閱讀:1066 作者:小新 欄目:關系型數據庫

這篇文章給大家分享的是有關如何解決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錯誤問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

五常市| 吕梁市| 喀什市| 宜州市| 定结县| 盐亭县| 巴青县| 新田县| 阿鲁科尔沁旗| 刚察县| 库车县| 西安市| 驻马店市| 张家川| 海伦市| 合江县| 阳高县| 含山县| 济阳县| 平果县| 岗巴县| 都昌县| 佛坪县| 十堰市| 大同县| 普兰县| 洞口县| 铁力市| 阿拉善左旗| 西和县| 抚宁县| 沅陵县| 南靖县| 海城市| 喀什市| 锡林郭勒盟| 宜兰县| 锡林浩特市| 会东县| 巴彦淖尔市| 柳河县|