ORA-01688:扩展ORACLE表空间操作

1、问题现象:

vasportal_20130111061515020_run.log:27:[2013-01-11 06:15:13:127][error][312]add contact group error,[

vasportal_20130111061515020_run.log:29:### Error updating database.  Cause: java.sql.SQLException: ORA-01688: unable to extend table SA03.T_CONTACT_GROUP partition P_CONTACT_GROUP_002 by 128 in tablespace TS_APP_DATA_03

vasportal_20130111061515020_run.log:31:### The error may involve contactGroup.addContactGroup-Inline

vasportal_20130111061515020_run.log:32:### The error occurred while setting parameters

2、问题原因:

(1) ORA-01688: unable to extend table ,这个错误表明表空间已使用完,且无法分配新的空间。这是因为表空间扩展方式为手动模式,而非自动模式;

3、解决法:

(1)、确定是哪个表空间用满了(查看表空间利用率):

SELECT c.ts#, c.name,  d.contents, d.extent_management, e.file_bytes, c.used,

       SUBSTR (c.used / e.file_bytes * 100, 1, 5)

  FROM (SELECT name, ts#, SUM(used) used

          FROM (SELECT a.allocated_space * (SELECT value  -- 查询db_block_size当前值

                                              FROM v$parameter

                                             WHERE name = 'db_block_size') / 1024/ 1024 used,

                        b.ts#, b.name

                  FROM v$filespace_usage a, v$tablespace b

         WHERE a.tablespace_id = b.ts#)

         GROUP BY name, ts#) c,

        dba_tablespaces d,

       (SELECT ts#, SUM(bytes) / 1024/ 1024 file_bytes

          FROM v$datafile

         GROUP BY ts#) e      

 WHERE c.name = d.tablespace_name

   AND e.ts# = c.ts#

 ORDER BY ts#

结果:

(2)现在要扩展表空间:

第一步:查看表空间的名字及文件所在位置:
select tablespace_name, file_id, file_name,
round(bytes/(1024*1024),0) total_space
from dba_data_files
order by tablespace_name
 
 

\

 
 
第二步:增大所需表空间大小:
 
alter database datafile '表空间位置'resize 新的尺寸
例如:
alter database datafile '\oracle\oradata\anita_2008.dbf' resize 4000m
 
对于oracle数据库的表空间,除了用手动增加大小外,还可以增加数据文件等方式扩展表空间大小。
 
方法一:增加数据文件个数
 
alter tablespace 表空间名称
     add datafile '新的数据文件地址' size 数据文件大小
例如:
alter tablespace ESPS_2008
     add datafile '\oracle\oradata\anita_2010.dbf' size 1000m
 
方法二:设置表空间自动扩展
alter database datafile '数据文件位置'
     autoextend on next 自动扩展大小 maxsize 最大扩展大小
例如:
alter database datafile '\oracle\oradata\anita_2008.dbf'
      autoextend on next 100m maxsize 10000m
 
方法三:查询表空间使用情况:
select a.tablespace_name,a.bytes/1024/1024 "sum MB",
(a.bytes-b.bytes)/1024/1024 "used MB",b.bytes/1024/1024 "free MB",
round (((a.bytes-b.bytes)/a.bytes)*100,2) "used%" from
(select tablespace_name,sum(bytes) bytes from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max (bytes) largest from dba_free_space group by tablespace_name)b
where a.tablespace_name=b.tablespace_name
order by ((a.bytes-b.bytes)/a.bytes) desc;
 
 

\

  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值