我不是 dba,但我遇到了一个数据库问题,它锁定了表并因此造成了很大的混乱。我从 oracle dba 获得了一些信息,如果有人可以帮助我找到问题的关键或指出我需要做什么,我将更多信息放在这里:
我有一份来自 oracle 的大报告,但我不理解 95% 的数据。
我不是 dba,但我遇到了一个数据库问题,它锁定了表并因此造成了很大的混乱。我从 oracle dba 获得了一些信息,如果有人可以帮助我找到问题的关键或指出我需要做什么,我将更多信息放在这里:
我有一份来自 oracle 的大报告,但我不理解 95% 的数据。
这看起来像常规的行级锁定。一行只能由一个用户一次修改。数据字典包含有关谁被阻止以及谁正在执行阻止的信息:
--Who's blocking who?
select
blocked_sql.sql_id blocked_sql_id
,blocked_sql.sql_text blocked_sql_text
,blocked_session.username blocked_username
,blocking_sql.sql_id blocking_sql_id
,blocking_sql.sql_text blocking_sql_text
,blocking_session.username blocking_username
from gv$sql blocked_sql
join gv$session blocked_session
on blocked_sql.sql_id = blocked_session.sql_id
and blocked_sql.users_executing > 0
join gv$session blocking_session
on blocked_session.final_blocking_session = blocking_session.sid
and blocked_session.final_blocking_instance = blocking_session.inst_id
left join gv$sql blocking_sql
on blocking_session.sql_id = blocking_sql.sql_id;
如果您了解系统,通常更容易关注“谁”在阻止而不是“什么”被阻止。上面的查询只返回了一些常见的列,但这些表中还有许多其他列可能有助于识别进程。