正在修改者表update的时候  好像服务器死机了,登陆用户端登不上,结果好半天登上了,修改没改过来而且,但结果在修改修改不了这张表了!可能是我在修改数据库的时候提交时候,前台也提交了,同时进行了,产生了锁定状态,结果谁都改不了了!
查询是否加锁的命令是什么?
怎么解锁?

解决方案 »

  1.   


    Oracle 查看 对象 持有锁的情况
    http://blog.csdn.net/tianlesoftware/article/details/6822321
      

  2.   

    我的表是 
    select * from office_yusuanzhibiaozj where workflowinstance_guid='{123456}'
     修改不了这个张表的内容了,for update也不行!一直是执行中!我要确切的解决办法啊!新手!直接告诉我解除的命令!
      

  3.   

    查看锁表的session,然后把session kill 掉。 上面的链接里有详细的说明。 学习还是需要一点钻研精神的!
      

  4.   

    Oracle的KILL锁表及清除session方法  2010-03-17 10:00:43|  分类: ORACLE数据库 |  标签: |字号大中小 订阅 .一、处理过程      1.通过查找出已被锁定的数据库表及相关的sid、serial#及spid:        select object_name as 对象名称,s.sid,s.serial#,p.spid as 系统进程号        from v$locked_object l , dba_objects o , v$session s , v$process p        where l.object_id=o.object_id and l.session_id=s.sid and s.paddr=p.addr;        2.在数据库中灭掉相关session:       alter system kill session 'sid,serial#';      --sid及serial#为第一步查出来的数据        3.从系统中灭掉与该session对应的进程:       kill -9 spid;      --spid为第一步中查出来的系统进程号      经过以上操作之后重新对之前锁定的对象进行操作应该就可以了。二、使用了相关表的基本介绍 •V$LOCKED_OBJECT中的列说明: XIDUSN:回滚段号XIDSLOT:槽号XIDSQN:序列号OBJECT_ID:被锁对象IDSESSION_ID:持有锁的sessionIDORACLE_USERNAME:持有锁的Oracle 用户名OS_USER_NAME:持有锁的操作系统 用户名PROCESS:操作系统进程号LOCKED_MODE:锁模式 •dba_objects的列说明(网上找的,懒得翻译了^_^) OWNER          Username of the owner of the object    OBJECT_NAME          Name of the object    SUBOBJECT_NAME          Name of the sub-object (for example,partititon)    OBJECT_ID          Object number of the object    DATA_OBJECT_ID          Object number of the segment which contains the object    OBJECT_TYPE          Type of the object    CREATED          Timestamp for the creation of the object    LAST_DDL_TIME          Timestamp for the last DDL change (including GRANT and REVOKE) to the object    TIMESTAMP          Timestamp for the specification of the object    STATUS          Status of the object    TEMPORARY          Can the current session only see data that it place in this object itself?    GENERATED          Was the name of this object system generated?    SECONDARY          Is this a secondary object created as part of icreate for domain indexes? •v$session的说明 V$SESSION是基础信息视图,用于找寻用户SID或SADDR常用列:SID:SESSION标识SERIAL#:如果某个SID又被其它的session使用的话则此数值自增加(当一个SESSION结束,另一个SESSION开始并使用了同一个SID)。AUDSID:审查session ID唯一性,确认它通常也用于当寻找并行查询模式USERNAME:当前session在oracle中的用户名。STATUS:这列用来判断session状态是:    Achtive:正执行SQL语句(waiting for/using a resource)    Inactive:等待操作(即等待需要执行的SQL语句)    Killed:被标注为删除 •v$process视图 v$process视图包含当前系统Oracle运行的所有进程信息。常被用于将Oracle或服务进程的操作系统进程ID与数据库session之间建立联系。常用列:ADDR:进程对象地址PID:oracle进程IDSPID:操作系统进程ID详解:一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库。但是shutdown immediate又怕可能进程杀不掉会一直停留在shutdown immediate,直接shutdown abort又怕损坏数据库。
    现在提供一种方法解决这种问题,那就是在ORACLE中杀不掉的,在OS一级再杀。
    一些ORACLE中的进程被杀掉后,状态被置为"killed",但是锁定的资源很长时间不释放,有时实在没办法,只好重启数据库。但是shutdown immediate又怕可能进程杀不掉会一直停留在shutdown immediate,直接shutdown abort又怕损坏数据库。
    现在提供一种方法解决这种问题,那就是在ORACLE中杀不掉的,在OS一级再杀。
    1.下面的语句用来查询哪些对象被锁:
    SELECT S.USERNAME,S.OSUSER,S.SID,S.SERIAL#,P.SPID FROM V$SESSION S,V$PROCESS
    P WHERE S.PADDR=P.ADDR AND S.USERNAME IS NOT NULL;
    2.下面的语句用来杀死一个进程:
    alter system kill session 'sid,serial#';
    【注】以上两步,可以通过Oracle的管理控制台来执行。
    如果出现题目的错误,可以
    select a.spid,b.sid,b.serial#,b.username from v$process a,v$session b where a.addr=b.paddr and b.status='KILLED' ;
    3.如果利用上面的命令杀死一个进程后,进程状态被置为"killed",但是锁定的资源很长时间没有被释放,那么可以在os一级再杀死相应的进程(线程),首先执行下面的语句获得进程(线程)号:
    select spid, osuser, s.program from v$session s,v$process p where
    s.paddr=p.addr and s.sid=33 (33就是上面的sid)
    4.在OS上杀死这个进程(线程):
    1)在unix上,用root身份执行命令:
    #kill -9 12345(即第3步查询出的spid)
    2)在windows(unix也适用)用orakill杀死线程,orakill是oracle提供的一个可执行命令,语法为:
    orakill sid thread
    其中:
    sid:表示要杀死的进程属于的实例名
    thread:是要杀掉的线程号,即第3步查询出的spid。
    例:c:>orakill orcl 12345
    Ps:这里要注意的是kill OS进程是在服务端操作,而不是你程序所在客户机。
      

  5.   

    select object_name as 对象名称,s.sid,s.serial#,p.spid as 系统进程号  from v$locked_object l , dba_objects o , v$session s , v$process p  where l.object_id=o.object_id and l.session_id=s.sid and s.paddr=p.addr;系统进程号是什么?