ORA-12801 并行查询服务器P001中发出错误信号 ORA-01652无法通过8192(在表空间XXX中)扩展temp段

oracle创建索引时碰到这个问题,考虑2部分问题,第一为temp表空间不足,第二为索引表空间不足。

排查思路如下:

1、查看索引占用表空间大小

select (bytes/1024/1024/1024)||'G',a.* 
  from dba_segments a 
 where a.owner = 'XXX' 
   and a.segment_name like 'XXX%' 
   and a.segment_type = 'INDEX';

2、查看表空间使用情况

SELECT a.tablespace_name "表空间名称", 
total / (1024 * 1024) "表空间大小(M)", 
free / (1024 * 1024) "表空间剩余大小(M)", 
(total - free) / (1024 * 1024 ) "表空间使用大小(M)", 
total / (1024 * 1024 * 1024) "表空间大小(G)", 
free / (1024 * 1024 * 1024) "表空间剩余大小(G)", 
(total - free) / (1024 * 1024 * 1024) "表空间使用大小(G)", 
round((total - free) / total, 4) * 100 "使用率 %" 
FROM (SELECT tablespace_name, SUM(bytes) free 
FROM dba_free_space 
GROUP BY tablespace_name) a, 
(SELECT tablespace_name, SUM(bytes) total 
FROM dba_data_files 
GROUP BY tablespace_name) b 
WHERE a.tablespace_name = b.tablespace_name;

如果发现表空间不够了,扩充之;

1、查看表空间文件位置

SELECT FILE_NAME,TABLESPACE_NAME,AUTOEXTENSIBLE, a.BYTES/ 1024 / 1024/1024 "文件大小(G)" 
FROM dba_data_files a
where a.TABLESPACE_NAME = 'XXX';

2、扩表空间

alter tablespace XXXadd datafile '/oracle/oradata/XXX/XXX.dbf' size 30G;

查看临时表空间文件位置语句:

select tablespace_name,
file_name,
user_bytes/bytes,
bytes / 1024 / 1024/1024 "file_size(M)",
autoextensible
from dba_temp_files t
where t.TABLESPACE_NAME = 'TEMP';

扩充临时表空间语句

alter tablespace temp add tempfile '/oracle/oradata/XXX/temp16.dbf' size 30G;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值