从品牌网站建设到网络营销策划,从策略到执行的一站式服务
查看哪个表被锁
创新互联-专业网站定制、快速模板网站建设、高性价比屏山网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式屏山网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖屏山地区。费用合理售后完善,十载实体公司更值得信赖。
select b.owner,b.object_name,a.session_id,a.locked_mode
from v$locked_object a,dba_objects b
where b.object_id = a.object_id
查看是哪个session引起的
select b.username,b.sid,b.serial#,logon_time
from v$locked_object a,v$session b
where a.session_id = b.sid order by b.logon_time
这种情况叫死锁,与网络质量无关。
最大的可能就是程序的原因。
如A进程修改a表的某条记录,修改完a表后,会继续修改b表的某条记录,然后提交事务。
这个时候,B进程在修改b表的那条记录,修改完后要去修改a表的那条记录,然后提交事务。
这样,当A修改完a尚未修改b,B修改完b尚未修改a的时候,就可能出现B进程等待A进程提交事务,A进程又在等待B进程提交事务,两个进程一直在等。
所以死锁就出现了。
1、查看是否有被锁的表:select b.owner,b.object_name,a.session_id,a.locked_mode from v$locked_object a,dba_objects b where b.object_id = a.object_id。
2、查看是哪个进程锁的select b.username,b.sid,b.serial#,logon_time from v$locked_object a,v$session b where a.session_id = b.sid order by b.logon_time。
3、杀掉进程alter system kill session 'sid,serial#';。
共享锁 独占锁,
行共享锁 ,行独占锁,表共享锁,表独占锁
1、在sql语句后面加上for update可以获得行锁。
2、捕捉返回的sqlcode 和 sqlerrmc 可以得到返回值和错误信息。
---
以上,希望对你有所帮助。
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图