ORA-04021 timeout occurred while waiting to lock object
用户要求删除一个数据库的用户 GREENPASS,在删除的过程中,报错如下:
drop user GREENPASS * ERROR at line 1: ORA-04021: timeout occurred while waiting to lock object NEWDR.HNDR_SMS_LOG
处理过程
1. 首先查询NEWDR.HNDR_SMS_LOG,这是一个'PROCEDURE';
2. 现在报错,不能对此对象进行锁定。
3. 看看什么会话在访问此对象:
select B.SID, b.USERNAME, b.MACHINE FROM V$ACCESS A, V$SESSION B WHERE A.SID = B.SID and a.OBJECT = 'HNDR_SMS_LOG' and a.TYPE = 'PROCEDURE';
SID USERNAME MACHINE ---------- ------------ ------------------- 520 NEWDR WORKGROUP\BONC02
4. 根据sid获取操作系统的进程号
select spid os_sid from v$process where addr = (select paddr from v$session where sid = &oracle_sid);
old 3: where addr = (select paddr from v$session where sid = &oracle_sid) new 3: where addr = (select paddr from v$session where sid = 520)
OS_SID ------------ 29360
5. 询问业务人员,可以直接杀掉进程
ps -ef|grep 29360 kill -9 29360
6. 重新尝试 SQL> drop user GREENPASS; 用户已丢弃
-----------------------------------------------
sid 为 520 对应的语句 部分如下:
INSERT /*+ APPEND */ INTO FACT_INFO_USER_BEFORE (ACCT_MONTH, USER_NO, DEVICE_NUMBER, SERVICE_CODE, AREA_ID, CITY_ID, USER_DINNER, INNET_MONTH, AVG_ARPU, ACCT_ARPU, IS_ACCT, USER_TYPE, EXPIRE_MONTH) SELECT /*+ USE_HASH(A,B,C,D,E,F,G)*/ :B1, C.USER_NO, C.DEVICE_NUMBER, C.TELE_TYPE, C.AREA_NO, C.CITY_NO, C.USER_DINNER, C.INNET_MONTH, A.AVG_FEE, B.ALL_FEE, NVL2(B.USER_NO, '1', '0'), (CASE WHEN F.CLUBMEM_LEVEL_SUB_CODE_LAST IN ('1', '2') AND F.CLUBMEM_LEVEL_SUB_CODE = '1' AND G.USER_NO IS NULL THEN '1' WHEN F.CLUBMEM_LEVEL_SUB_CODE_LAST IN ('1', '2') AND F.CLUBMEM_LEVEL_SUB_CODE = '2' AND G.USER_NO IS NULL THEN '2' WHEN F.CLUBMEM_LEVEL_SUB_CODE = '3' AND C.INNET_MONTH >= 4 AND A.AVG_FEE >= D.HIGH_STANDARD AND G.USER_NO IS NULL THEN '3' WHEN C.INNET_MONTH >= 4 AND A.AVG_FEE >= D.HIGH_STANDARD AND G.USER_NO IS NULL THEN '4' WHEN C.INNET_MONTH >= 4 AND A.AVG_FEE < D.HIGH_STANDARD AND A.AVG_FEE >= D.HIGH_STANDARD * 0.8 AND E.USER_TYPE <= '5' AND G.USER_NO IS NULL THEN '5' WHEN C.INNET_MONTH >= 4 AND A.AVG_FEE < D.HIGH_STANDARD AND A.AVG_FEE >= D.HIGH_STANDARD * 0.8 AND E.USER_TYPE > '5' THEN '6' WHEN C.INNET_MONTH >= 4 AND A.AVG_FEE < D.HIGH_STANDARD * 0.8 AND A.AVG_FEE >= 30 THEN '6'
ORA-04021 timeout occurred while waiting to lock object的更多相关文章
- ORA-04021:timeout occurred while waiting to lock object
编译某存储过程 ORA-04021 timeout occurred while waiting to lock object stringstringstringstringstring Cause ...
- 关于ORA-04021解决办法(timeout occurred while waiting to lock object)
某个应用正在锁定该表或者包 表为 select b.SID,b.SERIAL#,c.SQL_TEXT from v$locked_object a, v$session b, v$sqlarea c ...
- org.eclipse.jdi.TimeoutException:Timeout occurred while waiting for packet 1983.occurred
eclipse 增大junit内存配置 现象:eclipse在junit测试的时候出现如下错误 org.eclipse.jdi.TimeoutException:Timeout occurred wh ...
- Timeout occurred while waiting for latch: class 'ACCESS_METHODS_DATASET_PARENT'
前些天某个SQL Server数据库的错误日志爆出如下错误: Timeout occurred while waiting for latch: class 'ACCESS_METHODS_DATAS ...
- Timeout occurred while waiting for latch: class 'COLUMNSTORE_ROWGROUP_COLLECTION'
今天发现线上数据库主从延迟严重: SELECT ag.name AS ag_name, ar.replica_server_name AS ag_replica_server, dr_state.da ...
- org.eclipse.jdi.TimeoutException: Timeout occurred while waiting for packet 421. occured resuming VM.
环境: 导入excel的时候,会根据路径,读取EXCEL的数据. 原因: 电脑上的防火墙关闭
- 【我的Android进阶之旅】解决AndroidStudio编译时报错:Timeout waiting to lock artifact cache .
1. 错误描述 今天在Android Studio中,使用gradle命令的时候,出现了如下所示的错误: D:\GitLab Source\XTCLint>gradlew clean uploa ...
- Eclipse项目导入Android Stuio 配置出现 Timeout waiting to lock buildscript class cache for build file 'H:\studioproject\Generic_SN\build.gradle'
Eclipse项目导入Android Stuio 配置出现 Error:Timeout waiting to lock buildscript class cache for build file ...
- android studio :Timeout waiting to lock daemon addresses registry
一.开发中 android studio 突然遇到下面的错误提示: Error:Timeout waiting to lock daemon addresses registry. It is cur ...
随机推荐
- Android中ExpandableListView的使用
ExpandableListView是Android中可以实现下拉list的一个控件,具体的实现方法如下: 首先:在layout的xml文件中定义一个ExpandableListView < L ...
- 【Cocos2d-x 3.x】 精灵帧缓存和纹理缓存
转自泰然网(Cocos2d-x 3.x官方文档):精灵帧缓存:http://www.tairan.com/archives/6378/ 纹理缓存: http://www.tairan.com/ar ...
- Oracle----Job
最近需要使用到Oracle的定时Job,感觉到学习能力很重要,同时也感觉到及时总结和记笔记也很重要,现在开始总结Job的使用
- Android深度探索HAL与驱动开发 第四章 源代码下载和编译
前面说过Android移植主要就是Linux内核的移植,而Linux内核移植主要是Linux驱动的移植,所以为了开发和测试Linux驱动,有必要学习在Ubuntu Linux下如何搭建两套开发环境:A ...
- Codeforces Round #168 (Div. 2)
A. Lights Out 模拟. B. Convex Shape 考虑每个黑色格子作为起点,拐弯次数为0的格子构成十字形,拐弯1次的则是从这些格子出发直走达到的点,显然需要遍历到所有黑色黑色格子. ...
- ubuntu 配置vim(vimrc)
打开终端:ctrl+alt+t 进入vim文件:cd /etc/vim 打开vimrc文件:sudo gedit vimrc 然后在行末if语句前加上下面的内容," 这个符号为注释,后面内 ...
- 补交作业-第八周PSP
一.表格 C(分类) C(内容) S(开始时间) ST(结束时间) I(打断时间) △(净工作时间) 讨论 用户界面 9:30 10:40 15 55 编码 编码 13:20 16:30 10 180 ...
- Struts2向值栈中压入属性的方式
Struts2在初始化Action的时候会先向值栈中压入一个action对象,里面包含了各个属性,这些属性是怎么被压进去的?或者说是根据什么来压入的?直到2016年5月5日才理解,原来是在初始化act ...
- Bridge.NET
块作用域闭包问题 结果正确:1 容易引入JSB:1 public class Program { static List<Action> createActions() { List< ...
- ionic 常见问题
1.Couldn't find ionic.config.json file. ? a.在C:\Users\(Username)\.ionic目录下有ionic.config这个文件 添加后缀名jso ...