我的编程空间,编程开发者的网络收藏夹
学习永远不晚

解决oracle临时表空间的报错

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

解决oracle临时表空间的报错

报错信息:[HY000](1652) [Oracle][ODBC][Ora]ORA-01652: 无法通过 128 (在表空间 TEMP 中) 扩展 temp 段


 

原因分析:oracle临时表空间不足,事务执行一般将会报ora-01652无法扩展临时段的错误。因为oracle总是尽量分配连续空间,一旦没有足够的可分配空间或者分配不连续就会出现上述的现象。

 

回忆下临时表空间的作用:

 

  临时表空间主要用途是在数据库进行排序运算[如创建索引、order by及group by、distinct、union/intersect/minus/、sort-merge及join、analyze命令]、管理索引[如创建索引、IMP进行数据导入]、访问视图等操作时提供临时的运算空间,当运算完成之后系统会自动清理。

 

当临时表空间不足时,表现为运算速度异常的慢,并且临时表空间迅速增长到最大空间(扩展的极限),并且一般不会自动清理了。

 

解决办法:我们知道由于ORACLE将表空间作为逻辑结构-单元,而表空间的物理结构是数据文件,数据文件在磁盘上物理地创建,表空间的所有对象也存在于磁盘上,为了给表空间增加空间,就必须增加数据文件。先查看一下指定表空间的可用空间,使用视图SYS.DBA_FREE_SPACE,视图中每条记录代表可用空间的碎片大小。当然也可以扩展表空间。

1、增大临时表空间(或增加临时表空间文件)。

          2、设置临时数据文件自动扩展

 

步骤:

1、  查询临时表空间状态:  
SQL> col file_name for a20;

SQL> select tablespace_name,file_name,bytes/1024/1024file_size,autoextensible from dba_temp_files;   
解决oracle临时表空间的报错

2、  扩展临时表空间
SQL> alter database tempfile '/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf'resize 8192m;

或也可增加临时表空间文件

alter tablespace temp add tempfile‘/u01/app/oracle/oradata/CP7PV1DB/temp02.dbf’ size 8192m;

注:临时表空间文件如果已经32G,达到最大文件大小,只能添加文件。

SQL> alter tablespace temp add tempfile '/u01/app/oracle/oradata/CP7PV1DB/temp03.dbf' size 4G autoextend on next 128M maxsize 6G;


SQL> ALTER TABLESPACE TEMP DROP TEMPFILE '/u01/app/oracle/oradata/CP7PV1DB/temp03.dbf';


SQL> ALTER DATABASE TEMPFILE  '/u01/app/oracle/oradata/CP7PV1DB/temp03.dbf' RESIZE 6G;


3、  设置自动扩展

SQL> alter database tempfile'/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf' autoextend on next 10m maxsizeunlimited;

4、  扩展表空间时的报错

ERROR atline 1:

ORA-00376:file 201 cannot be read at this time

ORA-01110:data file 201: '/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf'

 

原因是临时表空间不知道什么原因offline了,修改为online后修改成功。

SQL>  alter database tempfile ‘/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf’online;

Database altered.

 

5、  删除临时表空间(补充)

SQL>drop tablespace temp01  including contents and datafiles;

SQL> ALTER DATABASE TEMPFILE  '/u01/app/oracle/oradata/CP7PV1DB/temp01.dbf' DROPINCLUDING DATAFILES;

Database altered.

注意:删除临时表空间的临时数据文件时,不需要指定INCLUDING DATAFILES 选项也会真正删除物理文件,否则需要手工删除物理文件。也不能直接删除当前用户的默认表空间,否则会报ORA-12906错误。如果需要删除某一个默认的临时表空间,则必须先创建一个临时表空间,然后指定新创建的表空间为默认表空间,然后删除原来的临时表空间。

6、  更改系统默认的临时表空间

--查询默认临时表空间

SQL> select *from database_properties where property_name='DEFAULT_TEMP_TABLESPACE';

PROPERTY_NAME                  PROPERTY_VALUE       DESCRIPTION

-------------------------------------------------- --------------------------------------------------

DEFAULT_TEMP_TABLESPACE        TEMP       Name of default temporary tablespace

--修改默认临时表空间

SQL> alterdatabase default temporary tablespace temp02;

Databasealtered.

我们可以查询是否切换为TEMP02:

SQL> select *from database_properties where property_name='DEFAULT_TEMP_TABLESPACE';

PROPERTY_NAME                  PROPERTY_VALUE       DESCRIPTION

-------------------------------------------------- ----------------------------------------

DEFAULT_TEMP_TABLESPACE        TEMP02     Name of default temporary tablespace

7、  查看临时表空间的使用率

SQL>SELECT temp_used.tablespace_name,

           total - used as "Free",

           total as "Total",

           round(nvl(total - used, 0) * 100 /total, 3) "Free percent"

      FROM (SELECT tablespace_name,SUM(bytes_used) / 1024 / 1024 used

              FROM GV_$TEMP_SPACE_HEADER

             GROUP BY tablespace_name) temp_used,

           (SELECT tablespace_name, SUM(bytes) /1024 / 1024 total

              FROM dba_temp_files

           GROUP BY tablespace_name) temp_total

    WHEREtemp_used.tablespace_name = temp_total.tablespace_name;

 

TABLESPACE_NAME                      Free      Total Free percent

---------------------------------------- ---------- ------------

TEMP                                 6876       8192       83.936

8、  查找消耗资源比较多的sql语句

Select se.username,
       se.sid,
       su.extents,
       su.blocks * to_number(rtrim(p.value)) asSpace,
       tablespace,
       segtype,
       sql_text
  from v$sort_usage su, v$parameter p, v$session se, v$sql s
 where p.name = 'db_block_size'
   and su.session_addr = se.saddr
   and s.hash_value = su.sqlhash
   and s.address = su.sqladdr
 order by se.username, se.sid;


先创建一个临时表空间,把这个表空间设置为默认的临时表空间,然后把以前的临时表空间删掉,再把数据文件删掉,很简单。

经验:

  • Oracle表空间中的数据文件只能增加不能删除.;可以移动数据文件,把表空间的指针rename一下.默认的临时表空间不能脱机.


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

解决oracle临时表空间的报错

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Oracle临时表空间过大如何解决

本篇内容主要讲解“Oracle临时表空间过大如何解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Oracle临时表空间过大如何解决”吧!方案一:增加临时表空间的大小1.临时表空间的使用情况题S
2023-06-27

oracle临时表空间不释放如何解决

如果Oracle临时表空间不释放,可以尝试以下方法解决:1. 检查是否有长时间运行的事务或会话占用了临时表空间。可以使用以下查询语句来查找:```SELECT s.sid, s.serial#, p.spid, s.username, s.
2023-09-15

oracle临时表空间无法释放怎么解决

当Oracle临时表空间无法释放时,可能是因为临时表空间中存在未提交的事务或者被长时间运行的查询锁定了表空间。以下是一些解决方法:确保没有未提交的事务:首先使用以下SQL语句检查是否有未提交的事务:SELECT * FROM V$TRAN
oracle临时表空间无法释放怎么解决
2024-04-09

MySQL临时表满了/临时表空间耗尽的解决方法

目录解决办法在 mysql 中,当你收到“临时表满了”的警报时,通常意味着 MySQL 在处理查询时创建的临时表空间已经耗尽。这可能会导致查询失败或性能下降。临时表通常用于处理一些需要排序、分组、或者使用临时数据存储
MySQL临时表满了/临时表空间耗尽的解决方法
2024-08-14

oracle创建临时表空间没反应如何解决

如果在Oracle数据库中创建临时表空间没有任何反应,有几种可能的解决方法:1. 检查用户权限:确保您具有适当的权限来创建表空间。您可以查看您的用户角色和权限,以确保您具有CREATE TEMPORARY TABLESPACE的权限。2.
2023-09-28

oracle删除表空间报错怎么解决

当Oracle删除表空间时报错,可能有以下几种情况:表空间中包含对象或数据文件正在被使用:在删除表空间之前,需要确保表空间中不包含任何对象或数据文件,并且没有正在使用的会话。可以使用以下命令查询表空间中是否有正在使用的对象:SELECT
2023-10-24

oracle怎么创建临时表空间

在Oracle数据库中,可以使用以下步骤创建临时表空间:首先,连接到Oracle数据库并以SYS用户身份登录。创建一个新的临时表空间,可以使用以下SQL语句:CREATE TEMPORARY TABLESPACE temp_tsTEMPF
oracle怎么创建临时表空间
2024-04-09

oracle怎么释放临时表空间

要释放Oracle数据库中的临时表空间,可以按照以下步骤进行操作:1. 首先,确保当前会话没有使用该临时表空间。可以通过执行以下查询语句来查看当前会话使用的临时表空间:```SELECT s.sid, s.serial#, p.spid,
2023-09-28

oracle临时表空间如何释放

在Oracle数据库中,临时表空间是用来存储临时数据的空间,一般用于排序、连接、分组等操作。临时表空间的释放可以通过以下步骤进行:确认当前是否还有会话在使用临时表空间。可以通过查询v$session视图或v$sort_usage视图来查看当
oracle临时表空间如何释放
2024-04-09

Oracle怎么删除临时表空间

要删除Oracle临时表空间,您可以按照以下步骤进行操作:首先,确保没有用户正在使用临时表空间。您可以通过执行以下SQL查询来检查:SELECT username FROM v$session WHERE tablespace_name
Oracle怎么删除临时表空间
2024-04-09

db2临时表空间不足怎么解决

当DB2临时表空间不足时,可以尝试以下解决方法:扩大临时表空间:可以通过增加临时表空间的容量来解决空间不足的问题。使用ALTER TABLESPACE命令可以增加临时表空间的大小。清理临时表空间:可以使用清理命令清理临时表空间中的临时数据。
db2临时表空间不足怎么解决
2024-04-09

编程热搜

目录