代码改变世界

kill_session_ora_14450.sql

  潇湘隐者  阅读(403)  评论(0编辑  收藏  举报

 

  之前总结过一篇博客“ORA-14450: attempt to access a transactional temp table already in use”,里面的脚本仅适合于讲述如何解决ORA-14450错误,在生产环境中,肯定需要快速解决问题,你可以使用下面脚本kill_session_ora_14450.sql找出涉及临时表的会话,并生成kill session的脚本。

 

SET LINESIZE 1080; 
SET COL KILL_SESSION FOR A80; 
SELECT s.SID, 
       s.SERIAL#, 
       s.STATUS, 
       s.PADDR, 
       'ALTER SYSTEM KILL SESSION ''' 
       || s.SID 
       || ',' 
       || s.SERIAL# 
       || ''' IMMEDIATE;' AS kill_cmd_text 
FROM   V$SESSION s 
WHERE  s.SID IN (SELECT SID 
                 FROM   V$ENQUEUE_LOCK T 
                 WHERE  T.TYPE = 'TO') 
       AND s.SID IN(SELECT SID 
                    FROM   V$LOCK 
                    WHERE  ID1 IN (SELECT OBJECT_ID 
                                   FROM   DBA_OBJECTS 
                                   WHERE  OBJECT_NAME = UPPER('&TABLE_NAME')
                                          AND OBJECT_TYPE = 'TABLE')); 
编辑推荐:
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 没有源码,如何修改代码逻辑?
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
历史上的今天:
2018-01-15 MS SQL 事务日志管理小结
2015-01-15 ORA-04091: table xxxx is mutating, trigger/function may not see it
点击右上角即可分享
微信分享提示