Oracle临时表游标未释放导致回滚段空间不足的解决方案

Oracle临时表游标未释放导致回滚段空间不足时会报出多个ORA-01650错误,造成数据库无法运行。本文我们主要就介绍了这一问题的解决方案,接下来就让我们来一起了解一下这部分内容。

先分析一下相关背景。产生报错的程序是一个数据处理模块,每天会将其他系统传过来的平面文件中的内容处理后放入数据库中,事务量很大。我们的系统是9i,划分了16个回滚段,其中两个大的batch回滚段,每个batch回滚段有6G的足够空间。而数据处理模块会在事务中指定使用BATCH1。

再分析报错的模块。检查相关的数据事务处理部分,由于业务需要保持数据的一致性,需要处理完1个文件后才能提交,中间如果出错就要全部回滚。经过确认,这部分代码有很长时间没有做改动了。然后再确认数据量,可以确认,今天(周五)是一周之内文件内容最少的一天。也就是说,如果由于数据量引起错误,其他时间的概率应该更大。

但是,有一点需要注意。指定回滚段是针对事务的,不是针对回滚段。也就是说,我们可以指定某个事务只使用某个回滚段,但是不能保证这个回滚段只被这个事务事务。当一个事务申请使用回滚段时,如果没有自己指定,oracle就会根据当时的各个回滚段的使用情况,分配一个最合适的回滚段给这个事务使用。因此,报回滚段空间不足的事务可能不一定就是导致回滚段空间不足的事务。还有一种可能就是,事务所指定的回滚段被其他事务所占用了。

于是我们就检查是否还有其他事务占用了该回滚段。

  1. SELECT s.sid, s.username, s.osuser, s.machine, s.program,  
  2. t.xidusn,t.ubafil,t.ubablk,t.used_ublk, t.log_io, t.phy_io, t.cr_get, t.cr_change,  
  3. r.name, q.sql_text  
  4. FROM v$session s,v$transaction t, v$RollName r, v$sqlarea q  
  5. WHERE s.saddr=t.ses_addr  
  6. and t.xidusn = r.usn  
  7. and s.sql_address = q.address(+)  
  8. and s.sql_hash_value = q.hash_value(+)And r,name = 'RBS_BATCH1'

 

果然发现有5个事务在占用BATCH1。但是发现会话状态为INACTIVE。这说明它们当时并没有运行INSERT/UPDATE/DELETE语句(曾经运行过,事务没有结束),而是将回滚段资源hung住了。

再查下那些对象被hung在BATCH1中,

 

  1. select l.session_id, l.os_user_name, l.oracle_username, o.owner, o.object_name, t.xidusn,t.ubafil,t.ubablk,t.used_ublk, t.used_urec,  
  2. t.log_io, t.phy_io, t.cr_get, t.cr_change, r.name  
  3. from v$locked_object l, dba_objects o, v$transaction t, v$RollName r  
  4. where l.object_id = o.object_id  
  5. and l.xidusn = t.xidusn  
  6. and l.xidslot = t.xidslot  
  7. and l.xidsqn = t.xidsqn  
  8. and t.xidusn = r.usn; 

 

嗯,都是同一个对象:“TMP_CNT_GRP”。通过SID确认,确实上面的事务都是将这个对象hung在RBS中的。

经过检查,原来这个对象是一个临时表。我们知道,临时表对象平时是不存在数据的。只有当一个会话使用临时表,并向表中插入数据后,oracle才会在临时表空间上创建它的数据对象。临时表数据之所以只被所调用会话看到,是实际上是在每个会话中创建了一个单独的数据对象,有各自的数据对象标号。因此尽管是同一个临时表,每个会话只是copy一个表结构,而创建了不同的数据对象,这样,会话之间就不会有数据干扰。而在一个会话中,对临时表数据对象的处理跟普通数据对象处理基本相同,其中就包括临时表对象在事务中的数据改动也会有回滚信息的产生。

回到我们的问题中。通过V$SESSION和V$SQL_AREA查到,这些会话都是调用了一个PLSQL函数,而且都是通过java调用的。

Review代码,终于发现潜在问题了:这个函数的结果是返回一个游标,而游标恰恰关联了这张临时表。

 

  1. INSERT INTO TMP_CNT_GRP ...  
  2.     SELECT...... ...      open v_cursor FOR  
  3.  select TMP.CDE,  
  4.          CAR.ID,  
  5.          CAR.NME,  
  6.          COUNT(DISTINCT TMP.NUM) TOTAL_CNT  
  7.    from TMP_CNT_GRP       TMP,  
  8.         CSS_CAR           CAR  
  9.    WHERE TMP.ID    = CAR.ID  
  10.   GROUP BY TMP.CDE, CAR.ID, CAR.NME;  
  11.  
  12.  RETURN v_cursor;  
  13.  
  14.  DELETE TMP_CNT_GRP; 

 

(这段代码其实还存在一个问题,也就是***的DELETE语句根本不会被调用)

从这段代码中可以看到,实际上在整个函数当中,临时表的数据根本不会被释放;而且也没有提交和回滚事务(尽管这是一个会话级的临时表)。占用的回滚段也不会被释放。这就存在这样的潜在问题,如果调用者不关闭会话或提交/回滚事务的话,它所占用的回滚段就不会被释放。事实上,经过让java开发人员检查代码,果然发现客户端在打开会话后,就没有关闭,知道客户端本身结束。

解决办法:

1、因为这是一个会话级的临时表,数据在事务提交后继续保留,因此在PLSQL函数中的insert语句后加上commit;

2、Java代码在使用完游标后关闭会话。

关于Oracle数据库的临时表游标未释放导致回滚段空间不足的问题就介绍到这里了,希望本次的介绍能够对您有所帮助。

【编辑推荐】

  1. 关于Oracle数据库闪回个性的详细介绍
  2. Oracle数据库对DDL语句和DML语句的事务管理
  3. Oracle数据库启动参数文件及相关SQL语句简介
  4. Oracle数据库的几种文件及表空间数据块的知识简介
  5. Oracle数据库查询登录用户名所属表空间及其使用情况

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/250998.html<

(0)
运维的头像运维
上一篇2025-04-28 18:41
下一篇 2025-04-28 18:43

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注