在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’是修改后的结果。