度量快速开发平台-专业、快速的软件定制快开平台

 找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
热搜: 部件 流程 SQL
查看: 1100|回复: 1
打印 上一主题 下一主题

[分享] ORA-00031:标记要终止的会话

[复制链接]

348

主题

3572

帖子

9328

积分

论坛元老

Rank: 8Rank: 8

积分
9328
跳转到指定楼层
楼主
发表于 2020-4-1 21:18:19 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
oracle中编译一个包的时候发现,只要一编译就卡死了,后来使用《oracle查询、Kill锁资源的SQL语句》方法查锁的时候发现包中用到的一些资源一直处于死锁状态。后来通过alter system kill session的方法去解锁,却发现出现如下图1所示的问题:


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



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

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

  1. SELECT s.sid,
  2.        s.serial#,
  3.        v.*,
  4.        ao.*
  5.   FROM v$locked_object v,
  6.        all_objects     ao,
  7.        v$session       s
  8. WHERE v.object_id = ao.object_id
  9.    AND s.sid = v.session_id;
复制代码

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

  1. -- 如有记录则表示lock,记录下SID和serial#,将记录下的SID和serial#替换下面的738,1429,即可接触lock。
  2. ALTER SYSTEM KILL SESSION '738,1429';
复制代码

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

  1. SELECT p.spid,
  2.        s.osuser,
  3.        s.program
  4.   FROM v$session s,
  5.        v$process p
  6. WHERE s.paddr = p.addr
  7.    AND s.sid = 37; -- 替换成相应的session_id
复制代码

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

  1. kill -9 1133
复制代码

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




分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
若現在就覺得失望無力,未來那麽遠妳該怎麽扛...
————————————————————————致自己
回复

使用道具 举报

328

主题

3738

帖子

8566

积分

作者

Rank: 7Rank: 7Rank: 7

积分
8566
QQ
沙发
发表于 2020-4-2 19:23:03 | 只看该作者
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|重庆度量科技  本站关键词:快速开发平台

GMT+8, 2024-11-24 16:08 , Processed in 0.173040 second(s), 26 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表