oracle11g plsql调试存储过程卡死的处理技巧

               

 

>> PLSQL调试存储过程卡死

有多次进行TEST调试存储过程,在某一个环境动不了,然后卡住,plsql界面进入假死状态了,而这个时候只有在windows里面的任务管理器里面强行关闭plsql的后台进程后,然后再次登录打开plsql,才能操作。

 

但是这种强性杀死plsql进程后重新登录plsql的做法不能解决问题,因为你上次调试存储过程的ka住的进程依然存在后台等待,并且会再次影响你第二次进行存储过程调试,那么有没有办法彻底解决呢?

 

如下图,元芳,你怎么看?

 

PS:plsql假死图:

图(1)  PLSQL假死图

 



第一种办法(PLSQL解决)

此时,重新打开第二个plsql窗口,使用dba账号登录,进入“Tools”--> “Sessions…”界面,可以看到所有的sessions会话进程,如下所示:

 

 

图(2)查看当前所有sessions

 

 

然后看到“Action”一栏目,看到有Test字样的,再看“Machine”确定是你操作的电脑发起的session,然后选中,右键弹出选中“kill”命令,然后选中“Yes”清除这条调试存储过程的会话即可,如下图所示:

图(3) 清除session

 

 

第二种办法(SQL)

执行sql语句:select * from v$session t where t.ACTION like'%Test%';找到当前进行存储过程调试的session,然后执行kill命令:

 

图(4) SQL查询出session


 



从图中可以看到 知道TEST被锁的用户为powerdesk,sid为1282,serial#为128, 执行alter system kill session'1282,128';清除session

SQL> altersystemkillsession'1282,128';                                                                                                                                                                                                                                          

 

System altered

 

 

 

SQL>

 

           
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PL/SQL调试存储过程可以通过PL/SQL Developer工具来实现。首先,确保PL/SQL Developer软件已经安装并且版本适配。然后,根据需要选择调试方法。 方法一是在SQL窗口中输入存储过程的代码或者在对象列表中找到对应的存储过程,然后右键选择测试。这样会自动生成测试脚本。另外,也可以新建测试窗口,手动输入测试语句。在生成测试语句后,需要对存储过程点击右键,选择添加调试信息。\[2\] PL/SQL Developer工具提供了强大的调试功能,可以与其他编程语言的IDE相媲美。通过调试功能,可以方便地排查存储过程调用报错或者其他对象的调用报错。这样可以避免完全依赖个人经验去排查问题,提高开发效率。\[3\] 需要注意的是,如果在PL/SQL Developer中使用多路会话方式进行调试,可能会出现卡死的情况。这是因为在RAC环境中,PL/SQL Developer每次新增一个会话时,数据会根据自身情况随机分配到不同的实例。如果调试和运行的会话被分配到不同的实例,就会出现卡死的情况。因此,在调试存储过程时,需要注意会话的配置方式。\[1\] #### 引用[.reference_title] - *1* *2* *3* [PLSQL存储过程调试](https://blog.csdn.net/yuchen488/article/details/108753639)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值