標籤:style java 使用 os io strong 檔案 資料
事務
作為邏輯處理的基本單位,對於資料庫操作來說由一條或者多條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
[java] view plaincopyprint?
- /**刪除使用者-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 block
- e.printStackTrace();
- try{
- conn.rollback();
- }catch (SQLException e1) {
- //TODO Auto-generated catch block
- e1.printStackTrace();
- }
- }
-
- returnflag;
- }
-