今天频繁编译一个存储过程时突然编译不过去,开始是一直不报错,每次编译都是卡主不动,然后PLSQL DEVELOPER会卡死,焦急的等待+重启电脑、重启plsql均无效。排除了网络问题后,想到是程序在执行无法编译亦或是dll锁了程序。百度一番,解决步骤如下:
多次编译不过去,终于报错了 ora-04021
ORA-04021: timeout occurred while waiting to lock object
1.查询程序是否资源锁定
select * from dba_ddl_locks where name='PROC_OL_CREDITORS_SUMMARY_D';PROC_OL_CREDITORS_SUMMARY_D无法编译的程序名。
查询结果 sid=156
select sid,serial# from v$session where sid=156;(156=上步骤查询的id)
-- 执行杀oraclesession命令。
alter system kill session '156,39324';
遇到新问题:
进一步通过杀操作系统进程
select spid, osuser, s.program from v$session s,v$process p where s.paddr=p.addr and s.sid=156 (156是上面的sid) 查出SPID = 2320
1)在unix上,用root身份执行命令:
#kill -9 2320(即第3步查询出的spid)
2)在windows(unix也适用)用orakill杀死线程,orakill是oracle提供的一个可执行命令,语法为:
orakill sid thread
其中:
sid:表示要杀死的进程属于的实例名
thread:是要杀掉的线程号,即第3步查询出的spid。
相关推荐
此文档中的内容针对的是oracle在编译存储过程时出现卡死现象的解决办法。这种现象主要是存储过程正在被调用。
oracle存储过程编译
linux系统中使用shell脚本对oracle存储过程进行编译
NULL 博文链接:https://forlab.iteye.com/blog/1821751
oracle 事务 回滚 存储过程 自用
oracle 存储过程导出excel oracle 存储过程导出excel oracle 存储过程导出excel oracle 存储过程导出excel oracle 存储过程导出excel
oracle 存储过程实例 oracle存储过程实例
本文实例讲述了Python使用cx_Oracle调用Oracle存储过程的方法。分享给大家供大家参考,具体如下: 这里主要测试在Python中通过cx_Oracle调用PL/SQL。 首先,在数据库端创建简单的存储过程。 create or replace ...
如果存储过程被锁住,可以使用这个存储过程解锁方法
oracle 存储过程 unwrap 图形解密 工具
oracle存储过程笔记oracle存储过程笔记oracle存储过程笔记oracle存储过程笔记oracle存储过程笔记oracle存储过程笔记oracle存储过程笔记oracle存储过程笔记oracle存储过程笔记oracle存储过程笔记
帆软报表调用Oracle存储过程如果存储过程定义中没有参数,但是设计器中缺弹出一个storeParameter1参数的解决插件
oracle存储过程加密破解 0
ibatis调用oracle存储过程分页
oracle 存储过程批量提交
oracle存储过程学习经典入门 非常好的 初学者必看
可以将SQL Server存储过程转为oracle存储过程的工具
使用java实现oracle存储过程。 共有3个小例子。实现的功能 1、无返回值的存储过程 如 insert 2、有返回值的存储过程(非列表)select id from tab 3、返回列表 如:select * from tab 顺便鄙视下csdn,作为一个it...
vba 调用oracle 存储过程vba 调用oracle 存储过程vba 调用oracle 存储过程vba 调用oracle 存储过程vba 调用oracle 存储过程
解决存储过程被锁无法编译的问题解决存储过程被锁无法编译的问题解决存储过程被锁无法编译的问题解决存储过程被锁无法编译的问题