今天碰到一个问题,有一张表不能操作,很可能是被锁了,首先想到的是kill session,于是执行了下列的脚本找到是哪个session有问题:

查看表是否被锁

SELECT /*+ rule*/

a.sid, b.owner, object_name, object_type

FROM v$lock a, all_objects b

WHERE TYPE = 'TM'

and a.id1 = b.object_id;

根据上面查询出的sid,找出对应的serial#:

SELECT sid,serial# FROM v$session WHERE sid = &sid;

发现有一个会话有锁sid 197,serial# 17,于是执行alter system kill session ‘197,17';大概等了30s中,pl/sql developer报出一个错误:ora-00031:标记要终止的会话。

解决方法:查出session的spid

select spid, osuser, s.program from v$session s, v$process p where s.paddr = p.addr and s.sid =197;

1. 在linux上, kill -9 12345

2. 在windows上,C:\Documents and Settings\gg>orakill orcl 12345

orcl:表示要杀死的进程属于的实例名

12345:是要杀掉的线程号

ORA-00031: session marked for kill

Cause: The session specified in an ALTER SYSTEM KILL SESSION command cannot bekilled immediately (because it is rolling back or blocked on a networkoperation), but it has been marked for kill. This means it will be killed as soonas possible after its current uninterruptible operation is done.

Action: No action is required for the session to be killed, but further executionsof the ALTER SYSTEM KILL SESSION command on this session may cause the sessionto be killed sooner.

下面是补充:

oracle中编译一个包的时候发现,只要一编译就卡死了,后来使用《oracle查询、Kill锁资源的SQL语句》方法查锁的时候发现包中用到的一些资源一直处于死锁状态。后来通过alter system kill session的方法去解锁,却发现出现如下图1所示的问题:

ORA-00031:标记要终止的会话

ORA-00031:标记要终止的会话

后来通过连接上oracle数据库所在的系统,然后kill掉进程解决,方法如下:

(1)查询被锁资源的sid、serial#:

SELECT s.sid,

s.serial#,

v.*,

ao.*

FROM v$locked_object v,

all_objects ao,

v$session s

WHERE v.object_id = ao.object_id

AND s.sid = v.session_id;

(2)利用上面的SQL查询出sid和serial#以后,利用下面SQL去kill session:

-- 如有记录则表示lock,记录下SID和serial#,将记录下的SID和serial#替换下面的738,1429,即可接触lock。

ALTER SYSTEM KILL SESSION '738,1429';

(3)如果上面的kill session报如上图1的错误,那么再用下面的SQL去查处session对应的spid:

SELECT p.spid,

s.osuser,

s.program

FROM v$session s,

v$process p

WHERE s.paddr = p.addr

AND s.sid = 37; -- 替换成相应的session_id

(4)连上oracle数据库所在的系统(我这里是Linux系统),记录下上面查到的spid(假设这里查到的是1133),然后使用下面语句来kill掉进程:

kill -9 1133

等待一会,等进程kill成功以后,再去查锁即可发现资源已经被释放。如果oracle安装在Windows系统上,请使用Windows系统的kill进程的方式去杀掉进程。

oracle+标记要,oracle ORA-00031:session marked for kill(标记要终止的会话)解决方法相关推荐

  1. ORA-00031: session marked for kill 标记要终止的会话

    原文转载处:http://moonsoft.itpub.net/post/15182/203828 一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长 ...

  2. ora-00031:session marked for kill处理oracle中杀不掉的锁

    转: 一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库.现在提供一种方法解决这种问题,那就是在ORACLE ...

  3. 【转】ora-00031:session marked for kill处理oracle中杀不掉的锁

    一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库.现在提供一种方法解决这种问题,那就是在ORACLE中杀不 ...

  4. ORA-00031: session marked for kill 处理Oracle中杀不掉的锁

    转自:http://bbs.erp100.com/thread-5934-1-1.html marked 一些ORACLE 中的进程被杀掉后,状态被置为"killed",但是锁定的 ...

  5. plsql连接本地oracle数据库,而远程主机却无法连接,出现无监听程序的解决方法(转)

    plsql连接本地oracle数据库,而远程主机却无法连接,出现无监听程序的解决方法(转) 参考文章: (1)plsql连接本地oracle数据库,而远程主机却无法连接,出现无监听程序的解决方法(转) ...

  6. vue使用marked解析markdown文本遇到的坑及解决方法

    vue使用marked解析markdown文本遇到的坑及解决方法 1. 前言 最近在搭建自己的博客网站 https://lyuanzhi.com,不免遇到了要把markdown文本转化为html代码的 ...

  7. oracle update卡死ORA-00031:标记要终止的会话

    一.现象描述      在ORACLE数据处理过程中,当某个PL/SQL developer正在运行创建一个临时表对大的数据进行暂存处理时,由于处理速度很慢,这时突然做了中断处理,甚至于直接从&quo ...

  8. oracle数据库imp导入失败提示:“不是有效的导出文件, 标头验证失败”解决方法,修改dmp文件里oracle数据库版本号方法

    报错信息如下,该报错主要是因为原来导出时的数据库版本和现有的数据库版本不匹配所致. C:\Users\Administrator>imp ncc2005zdh_0602/ufida file=D ...

  9. oracle中监听程序当前无法识别连接描述符中请求服务 的解决方法

    早上同事用PL/SQL连接虚拟机中的Oracle数据库,发现又报了"ORA-12514 TNS 监听程序当前无法识别连接描述符中请求服务"错误,帮其解决后,发现很多人遇到过这样的问 ...

最新文章

  1. C++调用openssl使用sha256,并取结果前64位作为uint64
  2. python编程入门指南磁力下载-使用python 将bt转磁力链接
  3. Linux新手入门:通过chmod改变文件权限--转
  4. Oracle PL SQL 精萃pdf
  5. OpenCASCADE:使用 XSTEPDRAW
  6. missing legacy device support
  7. IEEE 第二届大数据、人工智能与物联网工程国际会议 (IEEE-ICBAIE 2021)
  8. 小白使用ansible
  9. 一个游戏大量合服代表什么_一个女人哭了代表什么?这几点帮你分析
  10. 理解sklearn.feature.text中的CountVectorizer和TfidfVectorizer
  11. modelsim调用产生随机数及创建虚拟类
  12. ubuntu 禁用透明大页_禁用大内存页面
  13. jQuery过滤选择器 通过过滤条件选取需要的元素
  14. 微软推出Windows Lite,目标Chrome OS上网本
  15. C语言实现大数计算器
  16. iOS真机测试详细步骤及图解
  17. 一个遮罩层怎么遮罩两个图层_遮罩效果全解(13种方法)
  18. vue使用antv-G2
  19. 快捷方式自动修复小工具
  20. ubuntu windows 双系统 修改启动项名称

热门文章

  1. No slave process to process jobs, aborting 报错!!!
  2. 从ipa文件中导出图片
  3. java读取resouces目录下文件
  4. 安装漂亮的Faenza1.3与Faience0.5图标主题
  5. 模拟jquery链式访问
  6. Linux下SVN安装配置全程实录(转)
  7. java在容器中导入图片_Java程序员必学技术:@Import直接导入类,在容器@Configuration、@Component中是怎么直接导入类注册到容器的?...
  8. Hibernate 发展之路
  9. java启动监听器报错_JAVA通过JDBC连接Oracle数据库详解【转载】
  10. python类属性初始化_Python:如何模拟类属性初始化函数