標籤:style blog http java 使用 os io 檔案
事務
作為邏輯處理的基本單位,對於資料庫操作來說由一條或者多條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在事務這裡的處理相比在事務的處理上本質還是一致的。