Oracle交易處理及執行個體示範JDBC操作大量刪除

來源:互聯網
上載者:User

Oracle交易處理及執行個體示範JDBC操作大量刪除

事務

作為邏輯處理的基本單位,對於資料庫操作來說由一條或者多條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 block
e.printStackTrace();
try{
conn.rollback();
}catch (SQLException e1) {
//TODO Auto-generated catch block
e1.printStackTrace();
}
}
 
returnflag;
}

總結

總的來說,感覺還是對oracle很多內部的機制瞭解的有限。前幾天的設計模式講課,也讓想到這裡的一些東西才有了這篇部落格。只能說是非常淺顯的認知,oracle在事務這裡的處理相比在事務的處理上本質還是一致的。

Oracle 11g 在RedHat Linux 5.8_x64平台的安裝手冊

Linux-6-64下安裝Oracle 12C筆記

在CentOS 6.4下安裝Oracle 11gR2(x64)

Oracle 11gR2 在VMWare虛擬機器中安裝步驟

Debian 下 安裝 Oracle 11g XE R2

相關文章

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.