『壹』 sql Server2008登陸時出現錯誤..錯誤號10061
開始---控制面板---管理工具---計算機管理
選擇」SQLSever服務「右擊重新啟動 「SQLSever(MSSQLSEVER)」
『貳』 sql資料庫的問題。運行存儲過程的時候出現死鎖 該怎麼解決高分懸賞 只求解答。查跟殺死鎖的代碼是什麼
lock
Select V$SESSION.SID, DBA_OBJECTS.OBJECT_NAME, V$SESSION.OSUSER, V$SESSION.PROGRAM
From V$LOCKED_OBJECT
Left Join DBA_OBJECTS on V$LOCKED_OBJECT.OBJECT_ID = DBA_OBJECTS.OBJECT_ID
Left Join V$SESSION ON V$LOCKED_OBJECT.SESSION_ID = V$SESSION.SID
Order By V$SESSION.SID, DBA_OBJECTS.OBJECT_NAME
unlock(kill session)
alter system kill session 'sid,serial#';
『叄』 db2存儲過程執行表和存儲過程就死鎖怎麼處理
1、建議獲取snapshot for application 以及snapshot for locks,應可以確定是哪一句發生了鎖。
2、如果能肯定是這一句,如果可以直接在最後加上 with ur應該就可以了(如果業務邏輯容許的話)。
『肆』 MYSQL 存儲過程報錯Deadlock found when trying to get lock; try restarting transaction
這個死鎖估計是有數據沒了, 或者某個操作被回滾了
要避免這個問題方法有很多
事務盡量不要太復雜
在使用表或者行的時候, 盡量設定一個順序, 比如同一時間段線程A 競爭 1 2 資源, 線程 B 競爭 2 1 資源出現死鎖, 如果改成 A 使用 1 2 B 也是使用的 1 2 , 這樣再差也只會出現線程A/B去等待線程B/A執行完畢再去訪問資源
將一些容易出現死鎖的欄位改成索引, 這樣在競爭資源的時候mysql將不再上鎖[doge]
如果你是mysql資料庫, 則盡量避免使用 insert ... select 這樣的sql(oracle不用), 因為他會為你需要查詢的條件也上鎖, 這樣也會容易出現死鎖的問題
捕獲異常, 然後在出現這個異常的時候再次執行一次死鎖的sql語句
待續, 我也沒遇到更多的出現死鎖的情況了, 等遇到再說
以上幾點如果有錯的話, 請指出, 我們相互探討, 畢竟這也是我從筆記裡面找出來的, 可能有錯誤
『伍』 存儲過程一直報錯 但是編譯成功了 也沒有錯 調用時一直不成功報錯
下面是問題:
Oraclede 環境中,客戶那邊提出,執行存儲過程時出錯,信息:DBCustomException: ORA-00900: invalid SQL statement
關於這個問題之前也遇到過,一直找不到原因,沒解決,時好時壞,,由於客戶大部分是SQL Server,也就沒太在意,現在終於麻煩來了。
我用自己創建的用戶,通過P/L SQL 登陸,執行以下語句
--創建表
create table ttt
(
aa varchar(20)
)
--創建存儲過程
CREATE OR REPLACE PROCEDURE myproc
AS BEGIN
select * from ttt;
END
--執行
exec myproc
執行存儲過程時,開始報錯:ORA-00900:無效SQL語句 (上面那個錯誤的中文版-_-!)
這時候看右邊的存儲過程如下,有個紅叉,