鎖表:LOCK TABLE tablename IN 鎖模式 MODE;
創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括饒陽網(wǎng)站建設(shè)、饒陽網(wǎng)站制作、饒陽網(wǎng)頁制作以及饒陽網(wǎng)絡(luò)營(yíng)銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,饒陽網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到饒陽省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
解鎖:commit或rollback;
鎖模式有以下幾種:
ROW SHARE
ROW SHARE permits concurrent access to the locked table but prohibits users from locking the entire table for exclusive access. ROW SHARE is synonymous with SHARE UPDATE, which is included for compatibility with earlier versions of Oracle Database.
ROW EXCLUSIVE
ROW EXCLUSIVE is the same as ROW SHARE, but it also prohibits locking in SHARE mode. ROW EXCLUSIVE locks are automatically obtained when updating, inserting, or deleting.
SHARE UPDATE
See ROW SHARE.
SHARE
SHARE permits concurrent queries but prohibits updates to the locked table.
SHARE ROW EXCLUSIVE
SHARE ROW EXCLUSIVE is used to look at a whole table and to allow others to look at rows in the table but to prohibit others from locking the table in SHARE mode or from updating rows.
EXCLUSIVE
EXCLUSIVE permits queries on the locked table but prohibits any other activity on it.
一些ORACLE中的進(jìn)程被殺掉后,狀態(tài)被置為"killed",但是鎖定的資源很長(zhǎng)時(shí)間不釋放,有時(shí)實(shí)在沒辦法,只好重啟數(shù)據(jù)庫。現(xiàn)在提供一種方法解決這種問題,那就是在ORACLE中殺不掉的,在OS一級(jí)再殺。
1.下面的語句用來查詢哪些對(duì)象被鎖:
select object_name,machine,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;
2.下面的語句用來殺死一個(gè)進(jìn)程:
alter system kill session '24,111'; (其中24,111分別是上面查詢出的sid,serial#)
【注】以上兩步,可以通過Oracle的管理控制臺(tái)來執(zhí)行。
3.如果利用上面的命令殺死一個(gè)進(jìn)程后,進(jìn)程狀態(tài)被置為"killed",但是鎖定的資源很長(zhǎng)時(shí)間沒有被釋放,那么可以在os一級(jí)再殺死相應(yīng)的進(jìn)程(線程),首先執(zhí)行下面的語句獲得進(jìn)程(線程)號(hào):
select spid, osuser, s.program
from v$session s,v$process p
where s.paddr=p.addr and s.sid=24 (24是上面的sid)
4.在OS上殺死這個(gè)進(jìn)程(線程):
1)在unix上,用root身份執(zhí)行命令:
#kill -9 12345(即第3步查詢出的spid)
2)在windows(unix也適用)用orakill殺死線程,orakill是oracle提供的一個(gè)可執(zhí)行命令,語法為:
orakill sid thread
其中:
sid:表示要?dú)⑺赖倪M(jìn)程屬于的實(shí)例名
thread:是要?dú)⒌舻木€程號(hào),即第3步查詢出的spid。
例:c:orakill orcl 12345
這個(gè)和鎖定機(jī)制沒什么關(guān)系吧?你的需求只需要邏輯標(biāo)識(shí)就可以滿足了。
可以設(shè)定一個(gè) 鎖定狀態(tài)的字段,例如 LOCK 等等,名字你自己根據(jù)業(yè)務(wù)場(chǎng)景自己取了。當(dāng)提交領(lǐng)導(dǎo)審批這步之后,LOCK字段設(shè)置一個(gè)值,例如1,為鎖定狀態(tài),其他業(yè)務(wù)操作時(shí)先取得此字段狀態(tài)是否為1,為1不可修改。
領(lǐng)導(dǎo)批準(zhǔn)了之后,記錄不可修改,LOCK=1不動(dòng),如拒絕,LOCK=0,可重新修改。
這樣就可以滿足你的需求了,采用鎖機(jī)制并不能滿足你的要求。因?yàn)槟悴恢李I(lǐng)導(dǎo)什么時(shí)候去審批通過,你總不能這一段時(shí)間之內(nèi)都占用ORACLE的鎖吧?這是不合理的。
希望能對(duì)你有幫助。
lock table 表名 exclusive mode nowait; -- 鎖整個(gè)表
select * from 表名 where XXX for update nowaitl -- 鎖符合條件的記錄
在對(duì)指定表做append操作,其他再做truncate時(shí)候,會(huì)產(chǎn)生鎖表,如下驗(yàn)證步驟,
1、創(chuàng)建測(cè)試表,
create table test_lock(id number, value varchar2(200));
2、執(zhí)行append語句;并且不做提交,insert /*+append*/ into test_lock values(1,1);
3、再次執(zhí)行清表語句,truncate table test_lock;報(bào)鎖表錯(cuò)誤,
4、查看鎖表語句,發(fā)現(xiàn)被鎖表,
select b.object_name, t.*
from v$locked_object t, user_objects b
where t.object_id = b.object_id
安裝Oracle 11g會(huì)自帶一個(gè)叫做SQL Developer的工具,打開SQL Developer,
在SQL Developer中我們新建一個(gè)連接,點(diǎn)擊左上角的“綠色加號(hào)”
創(chuàng)建數(shù)據(jù)庫連接,
填寫完配置以后可以點(diǎn)擊“Test”來測(cè)試數(shù)據(jù)庫連接是否正確,如上圖所示,左下角有“Status:Success”則表明數(shù)據(jù)庫連接正確。
創(chuàng)建新用戶
連接登陸數(shù)據(jù)庫
接著為ORCL這個(gè)數(shù)據(jù)庫創(chuàng)建新用戶,如下圖所示填寫用戶名和密碼,以及為用戶指定表空間。如下圖所示為用戶分配權(quán)限
查看創(chuàng)建用戶和分配權(quán)限所對(duì)應(yīng)的sql代碼,如下圖所示。
使用新用戶創(chuàng)建數(shù)據(jù)庫連接,使用新賬戶創(chuàng)建數(shù)據(jù)庫連接的方法和第一步類似