oracle交易處理及執行個體示範jdbc操作大量刪除,oraclejdbc
事務
作為邏輯處理的基本單位,對於資料庫操作來說由一條或者多條sql語句來構成。當然還有針對非資料庫操作的,如在電腦中設定的還原點即是一個很好的應用。
對於事務的基本性質在另一篇中有所敘述:SQL 事務及執行個體示範
oracle和sql server在事務上區別
sql server中的事務一般分為隱含交易、明確交易、自動認可事務。
自動事務:對於sql server來說,當用戶端提交一條sql語句時,這時候sql server都會自動啟動一個事務;對於這樣的事務,在執行完sql語句後會自動認可。
顯示事務:這也是比較常見的使用的事務;其實實質上也就是在自動事務上,增加一個Begintran,conn.commit,end tran.
隱含交易:相比顯示事務需要開啟connection,隱含交易是預設開啟事務的Begin和資料庫連接的。當然後面還是要進行commit或rollback操作的。
而oracle的事務就沒有這麼如此豐富了,和sql server的隱含交易類似;無需開啟conn和Begin,只要在後續操作進行commit或rollback操作。
事務提交的機制
先瞭解一些基礎的概念,data buffer cache:相當於一塊串連硬碟檔案和oracle資料操作的高速唯讀緩衝。
SGA:在啟動oracle執行個體後,在記憶體中開闢的一塊記憶體空間,用於存放伺服器的控制資訊以及資料。
資料區塊:資料存放區的基本單位。
當串連到資料庫後,oracle為串連的使用者建立獨立的進程-影子進程,這個進程伴隨使用者的整個操作;
1.檢查資料區塊
2.構造undo資料區塊
以此來復原資料
3.產生redo日誌
用於重新操作的日誌存放在log buffer cache中。
4.lgwr進程啟動,提交事務並書寫所有記錄檔
java交易處理
TestDemo:結合位於java.sql下面的介面 PreparedStatement和oracle事務實現大量刪除
常用方法:
int[]executeBatch():
將一批命令提交給資料庫來執行,如果全部命令執行成功,則返回更新計數組成的數組。
voidsetString(int parameterIndex,
String x):
將指定參數設定為給定Java String 值。在將此值發送給資料庫時,驅動程式將它轉換成一個 SQL VARCHAR 或 LONGVARCHAR 值。
Demo
/**刪除使用者-2014年8月11日18:19:04 * @userId 使用者id數組 */publicBoolean DeleteUser(String[] userId){//一個安全執行緒的可變字串StringBuffersb=new StringBuffer();sb.append("deletefrom t_user where user_id =?");Connectionconn=null;PreparedStatementpsmt = null; Booleanflag=false; conn=DButil.getConnection();try {//關閉自動認可事務conn.setAutoCommit(false);//建立一個 PreparedStatement 對象來將參數化的 SQL語句發送到資料庫。psmt= conn.prepareStatement(sb.toString());//將一組參數添加到此 PreparedStatement 對象的批處理命令中。for(inti =0 ;i<userId.length;i++){psmt.setString(1,userId[i].trim());psmt.addBatch(); } // 執行批次更新 psmt.executeBatch(); // 語句執行完畢,提交本事務 conn.commit(); flag=true;}catch (SQLException e) {//TODO Auto-generated catch blocke.printStackTrace();try{conn.rollback();}catch (SQLException e1) {//TODO Auto-generated catch blocke1.printStackTrace();}} returnflag;}
總結
總的來說,感覺還是對oracle很多內部的機制瞭解的有限。前幾天的設計模式講課,也讓想到這裡的一些東西才有了這篇部落格。只能說是非常淺顯的認知,oracle在事務這裡的處理相比在事務的處理上本質還是一致的。
用JDBC訪問ORACLE資料庫,做DELETE操作,可以用JAVA多線程實現? ORACLE伺服器要怎配?
就像樓上說的。Oracle有自己的鎖機制。就算你開100條線,它還是一條一條刪除。不能同時刪除多項的。
對於大量資料更新,Oracle有建議一些最佳化措施。
1. 首先是把auto-commit給關閉。因為你每刪一條資料,oracle就要自動執行一次commit。commit是需要資源的。所以如果你手動設定為每刪資料1000條,執行一次commit. 那你就可以節省資源了。
2. 充分利用batch update。如果不用batch,每個delete命令都需要從網路上傳送到oracle。1萬個刪除命令,要有1萬次傳送。如果將100個刪除命令綁在一起送去Oracle執行。那就只要傳送100次就可以了。大大縮短所需時間和網路資源。
以上這些建議,都可以在Oracle參考裡查到。
Oracle中事務的處理,比如要對錶A操作,我先查詢在更新,是否需要將查詢放在事務,解答
按照你說的要求,查詢不用放在事務裡面,一般是在多個更新或刪除的情況下才用到事務,並且“多個更新或刪除”是要求原子性的,也就是要麼都執行,要麼都不執行。你說的這種情況,用不到事務,直接先查詢再更新就行。首先查詢是不會用到事務的,連續多個查詢頁不會用到事務,而第二步的更新,如果只涉及一個sql進行更新的話,也不會用事務(如果連續使用多個sql進行更新的話,需要用事務)。