oracle交易處理及執行個體示範jdbc操作大量刪除 2014年8月11日

來源:互聯網
上載者:User

標籤: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在事務這裡的處理相比在事務的處理上本質還是一致的。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.