oracle存儲過程的事務
❶ Oracle的函數或者存儲過程是處於同一個事務里嗎
1. 返回值的區別,函數有1個返回值,而存儲過程是通過參數返回的,可以有多個或者沒有2.調用的區別,函數可以在查詢語句中直接調用,而存儲過程必須單獨調用.函數一般情況下是用來計算並返回一個計算結果而存儲過程一般是用來完成特定的數據操作(比...
❷ oracle 一個存儲過程可以包含幾個事務,為什麼
一個存儲過程可以包含多個事務,但一般,大家都不想看到前面的事務成功了,而後面的事務失敗的情況發生,因此,放一個事務,統管整個存儲過程就ok了。
❸ oracle存儲過程的commit和rollback
commit和rollback不止是存儲過程中使用,所有的事務都需要用到這兩個關鍵字
commit是指將你所做的update,insert,delete數據的更改提交資料庫,完成此次事務,相當於你去商場購物,售貨員給你開了票後,你去收銀台付款完畢,這樣你才可以拿到你要買的貨物.
rollback是指將你所做的update,insert,delete數據的更改恢復更改前的狀態,此次事務取消,相當於你去商場購物,售貨員給你開了票後,你卻不去收銀台付款,而是離開了商場
❹ oracle 存儲過程事務控制
把第一個commit去掉既可,如下:
create or replace procere aaa is
var2 number;
begin SELECT Seq_Tbtopic.nextval INTO var2 FROM al;
insert into tbTopic values (var2 , 1, 1, '口語3333',1,3,2,'','');
insert into tbchildtopic values (Seq_Tbchildtopic.Nextval,var2,'','ck','/kangsi/Resource/test/B1/1_2_2_1_Emily_ck_.mp3','ck');
commit;
end aaa;
❺ oracle pl/sql 存儲過程中事務的控制,請大神請解釋!
如果P1是調用P2後,再進行DML操作 先執行P2的
既然P2中向外拋出錯誤 你可以在P1中 捕獲到異常rollback下即可
❻ oracle中的存儲過程有什麼作用
定義:存儲過程(Stored Procere )是一組為了完成特定功能的SQL 語句
集,經編譯後存儲在資料庫中。用戶通過指定存儲過程的名字並給出參數
(如果該存儲過程帶有參數)來執行它。存儲過程是資料庫中的一個重要
對象,任何一個設計良好的資料庫應用程序都應該用到存儲過程。
存儲過程是由流控制和SQL 語句書寫的過程,這個過程經編譯和優化後
存儲在資料庫伺服器中,應用程序使用時只要調用即可。在ORACLE 中,
若干個有聯系的過程可以組合在一起構成程序包。
優點:存儲過程只在創造時進行編譯,以後每次執行存儲過程都不需再重新編譯,而一般SQL語句每執行一次就編譯一次,所以使用存儲過程可提高資料庫執行速度。
2.當對資料庫進行復雜操作時(如對多個表進行Update、Insert、Query、Delete時),可將此復雜操作用存儲過程封裝起來與資料庫提供的事務處理結合一起使用。
3.存儲過程可以重復使用,可減少資料庫開發人員的工作量。
4.安全性高,可設定只有某用戶才具有對指定存儲過程的使用權。
你還是給我點分啥,寫得我手都酸痛了。
❼ oracle中的存儲過程,有什麼作用,以及怎麼在代碼中使用
定義:存儲過程(Stored Procere )是一組為了完成特定功能的SQL 語句
集,經編譯後存儲在資料庫中。用戶通過指定存儲過程的名字並給出參數
(如果該存儲過程帶有參數)來執行它。存儲過程是資料庫中的一個重要
對象,任何一個設計良好的資料庫應用程序都應該用到存儲過程。
存儲過程是由流控制和SQL 語句書寫的過程,這個過程經編譯和優化後
存儲在資料庫伺服器中,應用程序使用時只要調用即可。在ORACLE 中,
若干個有聯系的過程可以組合在一起構成程序包。
優點:存儲過程只在創造時進行編譯,以後每次執行存儲過程都不需再重新編譯,而一般SQL語句每執行一次就編譯一次,所以使用存儲過程可提高資料庫執行速度。
2.當對資料庫進行復雜操作時(如對多個表進行Update、Insert、Query、Delete時),可將此復雜操作用存儲過程封裝起來與資料庫提供的事務處理結合一起使用。
3.存儲過程可以重復使用,可減少資料庫開發人員的工作量。
4.安全性高,可設定只有某用戶才具有對指定存儲過程的使用權。
proc = connection.prepareCall("{ call SIM_MEDICARE.P_Isinblacklist(?,?,?,?,?) }");
proc.setString(1, 「」);設置傳入參數
proc.registerOutParameter(4, Types.VARCHAR);注冊傳出參數
proc.execute();執行過程
proc.getString(4)獲取結果
❽ 請教執行多個oracle存儲過程的事務問題
你這樣屬於2個事務在操作一個表。如果表中有唯一鍵,會有一個過程失敗的。如果沒有唯一鍵,會寫入20000條記錄。但是如果存儲過程里操作的表是動態傳進去的。如果表名不同,同時執行多個這個存儲過程是沒有影響的。
❾ Oracle中的事務問題!!
在存儲過程中寫一個語句用於對主表進行修改,然後
針對主表寫一個update觸發器,當主表進行修改進相關的副表就也能進行相應的修改了。
事務沒有提交之前是不會對資料庫中的數據進行操作的,只有commit以後才能實現,所以
要想得到修改後的記錄,必須在提交以後將你所需要值賦到一個變數中然後返回這個變數。
再在一個新的存儲過程中調用那一個專門用來獲取返回值的存儲過程,下次調用此方法時,
只需調用此新的存儲過程就行了,既獲取到修改後的值又執行了修改操作,何樂而不為呢?
至於怎麼獲取未修改以前的值就不用我說了,我知道你會做。
這樣的話,這個問題就解決了。。
這是我個人的觀點,如果不正確請予以批評和指證。謝謝。
❿ Oracle怎麼顯式開啟事務,開始事務跟鎖有什麼關系,在存儲過程中有時怎麼開啟和提交,回滾事務的
oracle使用語句savepoint sp_begintran開啟顯式事務,鎖本身和事務是沒有關系的,只要是資料庫的操作都會產生鎖。處於事務中的SQL語句只有這個事務提交(commit)之後,事務中的SQL語句影響的表記錄上的鎖才會釋放。鎖常見有共享鎖(select語句產生)和排它鎖(DML語句產生),如果一個表上載入有共享鎖,還可以疊加共享鎖,但不能疊加排它鎖。如果一個表上載入有排他鎖,就什麼鎖都不能加了,也就是說如果DML語句佔用過多的時間,這些資料庫效率就不高,就需要優化,當然select語句性能低了也不行。
每個存儲過程可以不用顯式事務,它本身就為你開啟了一個隱式事務,如果需要開啟顯示事務,就通過savepoint sp_begintran開啟,無論是不是顯式還是隱式事務,你都得通過commit work提交事務,通過exception捕捉SQL語句異常,在異常發生時需要回滾事務(rollback work)。