總結1:Oracle的鎖表與解鎖
select
s.username,
decode(l.type,'tm','table
lock','tx','row lock',null)
lock_level,
o.owner,
o.object_name,
o.object_type,
s.sid,
s.serial#,
s.terminal,
s.machine,
s.program,
s.osuser
from
v$session s,v$lock l,dba_objects o
where l.sid = s.sid
and l.id1 =
o.object_id(+)
and s.username is not null;
--kill session語句
alter system kill
session'50,492';
--以下幾個為相關表
SELECT * FROM v$lock;
SELECT * FROM
v$sqlarea;
SELECT * FROM v$session;
SELECT * FROM v$process ;
SELECT *
FROM v$locked_object;
SELECT * FROM all_objects;
SELECT * FROM
v$session_wait;
--1.查出鎖定object的session的資訊以及被鎖定的object名
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# ;
--2.查出鎖定表的session的sid,
serial#,os_user_name, machine name,
terminal和執行的語句
--比上面那段多出sql_text和action
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#;
--3.查出鎖定表的sid,
serial#,os_user_name, machine_name, terminal,鎖的type,mode
SELECT s.sid,
s.serial#, s.username, s.schemaname, s.osuser, s.process,
s.machine,
s.terminal, s.logon_time, l.type
FROM v$session s, v$lock
l
WHERE s.sid = l.sid
AND s.username IS NOT NULL
ORDER BY sid;
這個語句將尋找到資料庫中所有的DML語句產生的鎖,還可以發現,
任何DML語句其實產生了兩個鎖,一個是表鎖,一個是行鎖。
殺鎖命令
alter
system kill session 'sid,serial#'
SELECT /*+ rule */
s.username,
decode(l.type,'TM','TABLE LOCK',
'TX','ROW LOCK',
NULL)
LOCK_LEVEL,
o.owner,o.object_name,o.object_type,
s.sid,s.serial#,s.terminal,s.machine,s.program,s.osuser
FROM
v$session s,v$lock l,dba_objects o
WHERE l.sid = s.sid
AND l.id1 =
o.object_id(+)
AND s.username is NOT
NULL
如果發生了鎖等待,我們可能更想知道是誰鎖了表而引起誰的等待
以下的語句可以查詢到誰鎖了表,而誰在等待。
以上查詢結果是一個樹狀結構,如果有子節點,則表示有等待發生。
如果想知道鎖用了哪個復原段,還可以關聯到V$rollname,其中xidusn就是復原段的USN
col
user_name format a10
col owner format a10
col object_name format
a10
col object_type format a10
select lpad(' ',decode(l.xidusn
,0,3,0))||l.oracle_username
user_name,
o.owner,o.object_name,o.object_type,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
order by o.object_id,xidusn
desc
總結2:一個有用尋找指令碼:
column sid format 999;
column b format 9;
column object_name format
a30;
column locktype format a20;
select
v$lock.sid,
decode(v$lock.type,
'MR', 'Media Recovery',
'RT','Redo Thread',
'UN','User Name',
'TX',
'Transaction',
'TM', 'DML',
'UL', 'PL/SQL User
Lock',
'DX', 'Distributed Xaction',
'CF', 'Control
File',
'IS', 'Instance State',
'FS', 'File
Set',
'IR', 'Instance Recovery',
'ST', 'Disk Space
Transaction',
'TS', 'Temp Segment',
'IV', 'Library Cache
Invalida-tion',
'LS', 'Log Start or Switch',
'RW', 'Row
Wait',
'SQ', 'Sequence Number',
'TE', 'Extend
Table',
'TT', 'Temp Table',
'Unknown')
LockType,
rtrim(owner) || '.' || object_name
object_name,
decode(lmode, 0, 'None',
1,
'Null',
2, 'Row-S',
3,
'Row-X',
4, 'Share',
5,
'S/Row-X',
6, 'Exclusive','Unknown')
LockMode,
decode(request, 0, 'None',
1,
'Null',
2, 'Row-S',
3,
'Row-X',
4, 'Share',
5,
'S/Row-X',
6, 'Exclusive', 'Unknown') RequestMode,
ctime,
block b
from v$lock, all_objects
where sid > 6
and v$lock.id1 =
all_objects.object_id;
找到某表的鎖 所屬的sid.
alter system kill session 'sid,serial#';
即可
select
object_id,session_id,serial#,oracle_username,os_user_name,s.process
from
v$locked_object a,v$session s
where a.session_id=s.sid;
查出被lock 的對象
然後
alter system kill session 'sid,serial#';
知識點3:
LOCK TABLE
文法:
LOCK TABLE table_1 [,table_2, ...,
table_n] IN lock_mode MODE
NOWAIT
變數:
table_1,...,table_n: 一系列你想通過使用LOCK TABLE語句鎖住的資料庫表。
lock_mode:
對於某一資料庫表你要設定的鎖定模式。你可以從如下的鎖定模式中任選一個。
EXCLUSIVE
SHARE ROW
EXCLUSIVE
SHARE
SHARE UPDATE
ROW
SHARE
ROW EXCLUSIVE
NOWAIT: Oracle
will not wait to lock the given Table(s), if the Table(s)
is(are) not
available
例子:
SQL
LOCK TABLE
loan IN SHARE MODE ;
LOCK TABLE region IN EXCLUSIVE
MODE NOWAIT;
LOCK TABLE acct IN SHARE UPDATE MODE;
LOCK TABLE bank IN ROW EXCLUSIVE MODE NOWAIT;
LOCK
TABLE user IN SHARE ROW EXCLUSIVE MODE;
LOCK TABLE
branch IN ROW SHARE MODE NOWAIT;
commit
/