1、生成Kill Session語句
10余年的南通網站建設經驗,針對設計、前端、開發、售后、文案、推廣等六對一服務,響應快,48小時及時工作處理。營銷型網站的優勢是能夠根據用戶設備顯示端的尺寸不同,自動調整南通建站的顯示方式,使網站能夠適用不同顯示終端,在瀏覽器中調整網站的寬度,無論在任何一種瀏覽器上瀏覽網站,都能展現優雅布局與設計,從而大程度地提升瀏覽體驗。創新互聯從事“南通網站設計”,“南通網站推廣”以來,每個客戶項目都認真落實執行。
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#?;
/*或者
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(+);
/*--或者
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#;
*/
查詢鎖表
SELECT object_name, machine, s.sid, s.serial#
FROM gv$locked_object l, dba_objects o, gv$session s
WHERE l.object_id = o.object_id
AND l.session_id = s.sid;
2解鎖
--釋放SESSION SQL:
--alter system kill session 'sid, serial#';
ALTER system kill session '23, 1647';
3鎖表原因分析
1.對數據庫操作update,insert,delete時候,數據庫無法更新,操作等待時長,操作結果不發生改變
2.在程序中,底層(數據訪問層)操作時候,不成功,數據庫連接超時,無法操作,或者操作等待時長等現象
【加鎖的原理】:比如一個操作在進行修改一表,它沒完成,另一個操作也操作這張表時候就需要等待,前面操作結束之后才可進行操作。
4鎖表分類以及如何避免鎖表
Oracle鎖表 行級鎖 表級鎖
---- 行被排他鎖定
----在某行的鎖被釋放之前,其他用戶不能修改此行 ----使用 commit 或 rollback 命令釋放鎖
----Oracle 通過使用 INSERT、UPDATE 和 SELECT…FOR UPDATE 語句自動獲取行級鎖
SELECT…FOR UPDATE 子句 ―在表的一行或多行上放置排他鎖 ―用于防止其他用戶更新該行
―可以執行除更新之外的其他操作
―select * from goods where gid=1001 ―for update of gname;
―只有該用戶提交事務,其他用戶才能夠更新gname
FOR UPDATE WAIT 子句 ―Oracle9i 中的新增功能 ―防止無限期地等待鎖定的行 ―等待間隔必須指定為數值文字
―等待間隔不能是表達式、賦值變量或 PL/SQL 變量
―select * from goods where gid=1001 for update of gname wait 3 ―等待用戶釋放更新鎖的時間為3秒,否則超時。 ?表級鎖
―保護表的數據
―在多個用戶同時訪問數據時確保數據的完整性 ―可以設置為三種模式:共享、共享更新和 排他
語法:lock table table_namein mode; 共享鎖 ―鎖定表
―僅允許其他用戶執行查詢操作 ―不能插入、更新和刪除
―多個用戶可以同時在同一表中放置此鎖 ―lock table table_name ―in share mode [nowait];
― rollback 和commit 命令釋放鎖 ― nowait 關鍵字告訴其他用戶不用等待 共享更新鎖
―鎖定要被更新的行
―允許其他用戶同時查詢、插入、更新未被鎖定的行
―在 SELECT 語句中使用“FOR UPDATE”子句,可以強制使用共享更新鎖 ―允許多個用戶同時鎖定表的不同行
加鎖的兩種方法
lock table tab_name in share update mode; select column1,column2 from goods where goods where gid=1001
for update of column1,column2 排他鎖
―與其他兩種鎖相比,排他鎖是限制性最強的表鎖 ―僅允許其他用戶查詢數據
―不允許執行插入、刪除和更新操作
―在同一時間僅允許一位用戶在表上放置排他鎖 ―共享鎖與此相反
lock table tab_name in exclusive mode; lock table 表名[ 表名]... in share mode [nowait]
lock table 表名[ 表名]... in exclusive mode [nowait] lock table 表名[ 表名]... in share update mode[nowait]
-----------------------------------------------------------------------------------------------
LOCK Name
LOCK — 在事務中明確地鎖定一個表 LOCK [ TABLE ] name
LOCK [ TABLE ] name IN [ ROW | ACCESS ] { SHARE | EXCLUSIVE } MODE
LOCK [ TABLE ] name IN SHARE ROW EXCLUSIVE MODE 輸入
name
要鎖定的現存的表.
ACCESS SHARE MODE
注意: 這個鎖模式對被查詢的表自動生效。
這是最小限制的鎖模式,只與 ACCESS EXCLUSIVE 模式沖突。 它用于保護被查詢的表免于被并行的 ALTER TABLE, DROP TABLE 和 VACUUM 對同一表操作的語句修改。
ROW SHARE MODE
注意: 任何 SELECT...FOR UPDATE 語句執行時自動生效。 因為它是一個共享鎖,以后可能更新為 ROW EXCLUSIVE 鎖。
與 EXCLUSIVE 和 ACCESS EXCLUSIVE 鎖模式沖突。
ROW EXCLUSIVE MODE
注意: 任何 UPDATE, DELETE和 INSERT 語句執行時自動生效。
與 SHARE, SHARE ROW EXCLUSIVE, EXCLUSIVE 和 ACCESS EXCLUSIVE 模式沖突。
SHARE MODE
注意: 任何 CREATE INDEX 語句執行時自動附加。 共享鎖住整個表.
與 ROW EXCLUSIVE,SHARE ROW EXCLUSIVE,EXCLUSIVE 和 ACCESS EXCLUSIVE 模式沖突。這個模式防止一個表被并行更新。
SHARE ROW EXCLUSIVE MODE
注意: 這個模式類似 EXCLUSIVE MODE,但是允許其他事務的 SHARE ROW 鎖.
-----------------------------------------------------------------------------------------------
與 ROW EXCLUSIVE,SHARE,SHARE ROW EXCLUSIVE,EXCLUSIVE 和 ACCESS EXCLUSIVE 模式沖突。
EXCLUSIVE MODE
注意: 這個模式同樣比 SHARE ROW EXCLUSIVE 更有約束力. 它阻塞所有并行的 ROW SHARE/SELECT... FOR UPDATE 查詢。
與 ROW EXCLUSIVE,SHARE,SHARE ROW EXCLUSIVE,EXCLUSIVE 和 ACCESS EXCLUSIVE 模式沖突。
ACCESS EXCLUSIVE MODE
注意: 由語句 ALTER TABLE, DROP TABLE,VACUUM 執行時自動生效。這是最嚴格的約束鎖,它與所有其他的鎖 模式沖突并且保護一個被鎖定的表不被任何其他并行的操作更改。
注意: 一個不合格的 LOCK TABLE 同樣要求這個鎖模式 (例如,一條沒有顯式鎖模式選項的命令)。
輸出
LOCK TABLE 成功鎖定后的返回.
ERROR name: Table does not exist. 如果name 不存在,返回此信息.
描述
LOCK TABLE 控制一次事務的生命期內對某表的并行訪問. Postgres 在可能的情況下盡可能使用最小約束的鎖模式。 LOCK TABLE 在你需要時提供更有約束力的鎖。
RDBMS 鎖定使用下面術語:
EXCLUSIVE
排它鎖,防止其他(事務)鎖的產生.
SHARE
允許其他(事務)共享鎖.避免 EXCLUSIVE 鎖.
ACCESS
-----------------------------------------------------------------------------------------------
鎖定表結構.
ROW
鎖定獨立的行.
注意: 如果沒有聲明 EXCLUSIVE 或 SHARE,假設為 EXCLUSIVE.鎖存在于事務周期內.
例如,一個應用在 READ COMMITED 隔離級別上運行事務, 并且它需要保證在表中的數據在事務的運行過程中都存在。要實現這個你 可以在查詢之前對表使用 SHARE 鎖模式進行鎖定。這樣將保護數據不被 并行修改并且為任何更進一步的對表的讀操作提供實際狀態的數據, 因為 SHARE 鎖模式與任何寫操作需要的 ROW EXCLUSIVE 模式沖突,并且你的 LOCK TABLE name IN SHARE MODE 語句將等到所有并行的寫操作提交或回卷后才執行。
注意: 當在 SERIALIZABLE 隔離級別運行事務,而且你需要讀取真實狀態的數據時, 你必須在執行任何 DML 語句 (這時事務定義什么樣的并行修改對它自己是可見的) 之前運行一個 LOCK TABLE 語句。
除了上面的要求外,如果一個事務準備修改一個表中的數據, 那么應該使用 SHARE ROW EXCLUSIVE 鎖模式以避免死鎖情況(當兩個 并行的事務試圖以 SHARE 模式鎖住表然后試圖更改表中的數據時, 兩個事務(隱含的)都需要 ROW EXCLUSIVE 鎖模式,而此模式與并行的 SHARE 鎖沖突)。
繼續上面的死鎖(兩個事務彼此等待)問題, 你應該遵循兩個通用的規則以避免死鎖條件:
事務應該以相同的順序對相同的對象請求鎖。
例如,如果一個應用更新行 R1 然后更新行 R2(在同一的事務里), 那么第二個應用如果稍后要更新行 R1 時不應該更新行 R2(在 同一事務里)。相反,它應該與第一個應用以相同的順序更新行 R1 和 R2。
事務請求兩個互相沖突的鎖模式的前提:其中一個鎖模式是自沖突的 (也就是說,一次只能被一個事務持有)。 如果涉及多種鎖模式,那么事務應該總是最先請求最嚴格的鎖模式。
這個規則的例子在前面的關于用 SHARE ROW EXCLUSIVE 模式取代 SHARE 模式的討論中已經給出了。 -----------------------------------------------------------------------------------------------
注意: Postgres 的確檢測死鎖, 并將回卷至少一個等待的事務以解決死鎖。
注意
LOCK 是 Postgres 語言擴展.
除了ACCESS SHARE/EXCLUSIVE 鎖模式外,所有其他 Postgres 鎖模式和 LOCK TABLE 語句都與那些在 Oracle 里面的兼容。
LOCK 只在事務內部使用.
用法
演示在往一個外鍵表上插入時在有主鍵的表上使用 SHARE 的鎖:
BEGIN WORK;
LOCK TABLE films IN SHARE MODE; SELECT id FROM films
WHERE name = 'Star Wars: Episode I - The Phantom Menace';
-- 如果記錄沒有返回則回卷
INSERT INTO films_user_comments VALUES
(_id_, 'GREAT! I was waiting for it for so long!'); COMMIT WORK;
在執行刪除操作時對一個有主鍵的表進行 SHARE ROW EXCLUSIVE 鎖:
BEGIN WORK;
LOCK TABLE films IN SHARE ROW EXCLUSIVE MODE; DELETE FROM films_user_comments WHERE id IN (SELECT id FROM films WHERE rating 5); DELETE FROM films WHERE rating 5; COMMIT WORK; 兼容性 SQL92
在SQL92里面沒有LOCK TABLE ,可以使用 SET TRANSACTION 來聲明當前事務的級別. 我們也支持這個,參閱 SET TRANSACTION 獲取詳細信息。
1、在做Oracle監聽程序測試時,發現帳戶已經被鎖定。
2、在數據庫安裝電腦上,點擊開始打開運行窗口。
3、在運行窗口輸入CMD,調出命令提示符界面。
3、在命令提示符下面,用管理員身份登入到數據庫sqlplus / as sysdba。
4、輸入解鎖命令alter user Scott account unlock后回車。
5、看見用戶已更改的字樣,表示命令已成功執行。
6、再切換到監聽程序驗證,原來的ora-28000帳戶被鎖定的提示已經不存在了。用戶解鎖成功。
本文標題:oracle如何刪除鎖,oracle被鎖定怎么解除
標題URL:http://vcdvsql.cn/article28/hspgcp.html
成都網站建設公司_創新互聯,為您提供企業建站、ChatGPT、網站改版、網站營銷、手機網站建設、做網站
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯