【Oracle】表空间超标如何处理

来源:互联网 发布:最新越狱软件源 编辑:程序博客网 时间:2024/04/28 03:27

1、查询表空间使用状况;

首先要查询表空间,可以一个个查,也可以一起查询,找到自己的表空间数据信息;尤其要找到【表空间具体名称】查询语句如下:

SELECT UPPER(F.TABLESPACE_NAME) "表空间名",D.TOT_GROOTTE_MB "表空间大小(M)",D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),'990.99') "使用比",F.TOTAL_BYTES "空闲空间(M)",F.MAX_BYTES "最大块(M)"FROM (SELECT TABLESPACE_NAME,ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,ROUND(MAX(BYTES) / (1024 * 1024), 2) MAX_BYTESFROM SYS.DBA_FREE_SPACEGROUP BY TABLESPACE_NAME) F,(SELECT DD.TABLESPACE_NAME,ROUND(SUM(DD.BYTES) / (1024 * 1024), 2) TOT_GROOTTE_MBFROM SYS.DBA_DATA_FILES DDGROUP BY DD.TABLESPACE_NAME) DWHERE D.TABLESPACE_NAME = F.TABLESPACE_NAMEORDER BY 4 DESC;

2、查询【表空间文件名称】

找到自己的目标【表空间】,如果超标了,进入下一步,找到表空间文件存放位置:

SELECT * from dba_data_files WHERE tablespace_name like 'USERS%';

如果确切知道要查询的表空间名,可以直接等号操作:

SELECT * from dba_data_files WHERE tablespace_name ='你的表空间名称';

3、增加【最大数据块】大小和表空间大小;

重新规定表空间大小(RESIZE)和扩展最大数据块大小(MAXSIZE);这里DATAFILE后面是表空间文件的目录,要带文件类型的;我这里是DBF,你自己的要根据自己文件名替换;

--增加当前数据文件的大小41054ALTER DATABASEDATAFILE '表空间目录\表空间名称.DBF'RESIZE 30000M;--在使用过程中,如果想改变某个数据块的最大大小,可以ALTER DATABASEDATAFILE '表空间目录\表空间名称.DBF'AUTOEXTEND ONMAXSIZE 30000M;

4、注意

RESIZE和MAXSIZE会收到两个限制:
1.是硬盘的物理内存大小,这个大家都知道;
2.是数据块的大小和数据文件大小是有关联的;如果数据块大小是8K,能创建的最大数据大小是2^22*8K=32G;