原文地址:http://itindex.net/detail/54044-%E9%9D%A2%E8%AF%95-%E6%80%BB%E7%BB%93-insert
今天去面試被這個問題問掛啦,一開始真沒聽懂他說的啥,本來想用分表分庫這種高大上的東西忽悠一下,后來還是說不知道就走人, 現總結下如何解決這個問題:
1.臨時方案1:查看鎖表情況並處理鎖表
/*
*locked
*query locked object and analyse reason,kill it
*
*/
select 'alter system kill session ''' || SID || ',' || SERIAL# || ''';'
from (select distinct a.sid,
a.Serial#,
status,
machine,
LOCKWAIT,
logon_time
from v$session a, v$locked_object b
where (a.status = 'ACTIVE' or a.status = 'INACTIVE')
and a.sid = b.session_id
and b.ORACLE_USERNAME = 'XYHISTEST' --加上用戶名可過濾用戶資源
)
/*2、批量執行第一步生成的語句
alter system kill session 'sid,serial#';
alter system kill session '6976,33967';*/
/*3、查詢oracle用戶名,機器名,鎖表對象*/
SELECT l.session_id sid,
s.serial#,
l.locked_mode,
l.oracle_username,
l.os_user_name,
s.machine,
s.terminal,
o.object_name,
s.logon_time
FROM v$locked_object l, all_objects o, v$session s
WHERE l.object_id = o.object_id
AND l.session_id = s.sid
ORDER BY sid, s.serial#;
/*3.或者*/
select s.SID, s.OSUSER, p.spid as OSPID, s.MACHINE, s.TERMINAL, s.PROGRAM
from v$session s, v$process p
where s.sid = 6 --session_id
and s.paddr = p.addr;
/*4、查詢是執行何sql語句導致鎖表的*/
select b.sql_text
from v$session a, v$sql b
where a.sid = 6 --session_id
and a.SQL_ADDRESS = b.ADDRESS(+);
/*5、查詢是執行何sql語句導致鎖表的*/
SELECT l.session_id sid,
s.serial#,
l.locked_mode,
l.oracle_username,
s.user#,
l.os_user_name,
s.machine,
s.terminal,
a.sql_text,
a.action
FROM v$sqlarea a, v$session s, v$locked_object l
WHERE l.session_id = s.sid
AND s.prev_sql_addr = a.address
ORDER BY sid, s.serial#;
2.臨時方案2:流量控制,和寫入頻率控制:
(1)可以在接入層,應用層,服務層,數據訪問層控制流量,
(2)也可以用消息隊列異步控制寫入數據到數據庫的速度,或者RPC工具緩存數據到隊列,控制寫入到數據庫的頻率。
3.長期方案:根據實際業務做好數據切分,也就是分表,這個也是最復雜的。
