阿宝 Keep Walking......


JUST DO IT, DO YOUR BEST ! -- 勿在浮沙筑高台

  BlogJava :: 首页 :: 联系 :: 聚合  :: 管理
  49 Posts :: 6 Stories :: 26 Comments :: 0 Trackbacks
在Linux 下使用SQL Plus
# su oracle
# sqlplus /nolog
SQL> connect / as sysdba


在SQL Plus中删除字符
Ctrl + backspace键

查看被锁的表

select p.spid,a.sid,a.serial#, c.object_name,b.session_id,b.oracle_username,b.os_user_name from v$process p,v$session a, v$locked_object b,all_objects c where p.addr=a.paddr and a.process=b.process and c.object_id=b.object_id

或者用
col object_name for a30
col machine for a20
select object_name,machine,s.sid,s.serial#
from v$locked_object l,dba_objects o ,v$session s
where l.object_id = o.object_id and l.session_id=s.sid;

杀掉被锁的进程
alter system kill session '42,21993';
(其中24,111分别是上面查询出的sid,serial#)

如果利用上面的命令杀死一个进程后,进程状态被置为 "killed", 但是锁定的资源很长时间没有被释放,那么可以在os一级再杀死相应的进程(线程),首先获得进程(线程)号:
select spid, osuser, s.program
from v$session s,v$process p
where s.paddr=p.addr and s.sid=#sid; (#sid是上面的sid)

在操作系统中杀掉相应的进程(线程):
(1)在Linux上,用root身份执行命令:

kill -9 12345(12345是第3步查询出的spid)
(2)在windows 用orakill杀死线程,orakill是oracle提供的一个可执行命令,语法为:orakill sid thread

其中:

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

thread:是要杀掉的线程号,即第3步查询出的spid。

例:c:>orakill orcl 12345
注:可以写一个组合查询的存储过程来自动执行上述四步操作,方便地杀光所有不自动释放资源的进程,但一般情况下不推荐这样做,毕竟在系统中用root用户kill进程本身就是有一定的风险的!


 查看连接的进程

SELECT sid, serial#, username, osuser FROM v$session;

 

杀掉进程

alter system kill session 'sid,serial#';

执行上一条SQL
/

修改上一条SQL
c/sd_contact/oracl.sd_contact
其中‘sd_contact’是要修改的,‘oracl.sd_contact’是修改后的结果。

posted on 2008-09-05 14:58 阿宝 阅读(211) 评论(0)  编辑  收藏 所属分类: 数据库