oracle編譯存儲過程卡死
A. oracle存儲過程為什麼一編譯就掛死,是鎖住了嗎是不是跟表一樣有鎖的機制怎麼解鎖呢
不是因為鎖住了,是因為你編譯的時候,正好有人在調用你的那個存儲過程,
B. 問一個關於Oracle的存儲過程出現invalid的問題
Oracle中遇到「See無效」的錯誤提示,意味著存儲過程未能成功編譯。在編寫存儲過程、函數或包時,都需要經過編譯才能在Oracle資料庫中使用。如果存儲過程顯示無效,那麼它在編譯過程中出現了問題。
具體來看,See存儲過程的問題在於使用了獨立的SELECT查詢語句。在Oracle中,存儲過程不允許存在獨立的SELECT查詢語句,即不能直接返回結果集的SELECT語句。這一限制是因為Oracle的PL/sql語句塊設計如此。
如果你需要讓存儲過程返回結果集,可以考慮使用游標來實現。游標是一種處理數據集的方法,可以在存儲過程中用來臨時存儲和處理查詢結果。另一種方法是使用索引表,這是一種特殊的表結構,可以作為存儲過程的輸出參數。
需要注意的是,SQL Server用戶可能會遇到這種問題,因為SQL Server允許獨立的SELECT查詢語句。但在Oracle中,為了保持數據一致性、安全性和性能,這種直接返回結果集的查詢語句被禁止。
因此,當編寫Oracle存儲過程時,應避免使用獨立的SELECT查詢語句,並考慮使用游標或索引表來返回結果集。通過這種方式,可以確保存儲過程在編譯時不會出現無效的問題。
C. oracle 編譯包的時候,一直提示正在編譯
編譯的存儲過程的時候,程序死住,等待一會出現ora-04021錯誤解決辦法:
1.可能被鎖住
查看v$lockedselect b.sid,b.serial#,b.machine,b.terminal,b.program,b.process,b.status from v$lock a , v$session b
where a.SID = b.SID
得到死鎖session的SID,SERIAL#參看這個是否為你自己用戶下的,然後kill掉session
2.可能被掛起
查看v$session_waitselect b.serial#,a.* from v$session_wait a,v$session
bwhere a.sid = b.sid得到等待的session的sid和serial#3.查看dba_ddl_locksselect
session_id sid, owner, name, type,
mode_held held, mode_requested request
from dba_ddl_locks
where name = '&your_package_name'
D. Oracle使用merge into 編寫存儲過程 遇編譯錯誤:PL/SQL: ORA-00926: 缺失 VALUES 關鍵字
Oracle使用猜碼掘merge into 編寫存儲過程 遇編譯錯誤,是設置錯誤造成的,解決方法如下:
1、首先穗核新建存儲過程,Create or ReplaceProcere CHK_SYS_EMP 檢查系統工號。
E. ORACLE 存儲過程無法編譯,編譯就卡死
你怎麼查的鎖?v$locked_object?dba_ddl_locks查了沒,可能是ddl的鎖,如果不能編譯,一編譯就死,也可能是ddl的鎖導致的,以前碰到過。如果能找到鎖,那就簡單了。
不過還碰到過一種特別扯淡的情況,關掉自己的連接,然後換一台電腦從新來過,就OK了,這種情況也碰到過。
F. oracle存儲過程 處於無效狀態
1、你的存儲過程有錯誤,編譯不通過。處理於無效狀態。
2、問題
存儲過程中隱式游標的select語句必須要有into子句。
而select*fromtemp_syckzl_zy這是一個沒有意義的語句;
應改為如:selectcol1intov_col1fromtemp_syckzl_zy;
註:col1為表中一欄位,v_col1為一變數
G. ORACLE 存儲過程被鎖,編譯不了,怎麼解鎖
可用SYS登錄,然後查詢如下語句:
查找存儲過程OPERATIONDATA_IMP被哪些session鎖住而無法編譯
select * FROM dba_ddl_locks where name =upper('OPERATIONDATA_IMP');
從而得到session_id,然後通過
select t.sid,t.serial# from v$session t
where t.sid=&session_id;
得到sid和serial#
最後用alter system kill session 'sid,serial#'; kill 相關session即可。
H. ORACLE 存儲過程被鎖,編譯不了,怎麼解鎖
一些ORACLE中的進程被殺掉後,狀態被置為"killed",但是鎖定的資源很長時間不釋放,有時實在沒辦法,只好重啟資料庫。現在提供一種方法解決這種問題,那就是在ORACLE中殺不掉的,在OS一級再殺。
1.下面的語句用來查詢哪些對象被鎖:
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.下面的語句用來殺死一個進程:
alter system kill session '24,111'; (其中24,111分別是上面查詢出的sid,serial#)
【注】以上兩步,可以通過Oracle的管理控制台來執行。
3.如果利用上面的命令殺死一個進程後,進程狀態被置為"killed",但是鎖定的資源很長時間沒有被釋放,那麼可以在os一級再殺死相應的進程(線程),首先執行下面的語句獲得進程(線程)號:
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上殺死這個進程(線程):
1)在unix上,用root身份執行命令:
#kill -9 12345(即第3步查詢出的spid)
2)在windows(unix也適用)用orakill殺死線程,orakill是oracle提供的一個可執行命令,語法為:
orakill sid thread
其中:
sid:表示要殺死的進程屬於的實例名
thread:是要殺掉的線程號,即第3步查詢出的spid。
例:c:>orakill orcl 12345
I. Oracle 定義存儲過程不能執行怎麼辦
無效狀態有兩種可能:
1、一種是你的存儲過程編輯沒有成功,創建了,但裡面有語法錯誤。