java中的事物處理是怎么回事?
什么是事物,怎么處理呢?事務具有這些特征:原子性、一致性、隔離性、持久性。在java中最常見的事務就是數據庫操作了。舉個例子就是完成一件事要在A表里插一條數據,B表里刪一條數據,這兩步要都成功,這件事才算做完。其中一步失敗,那么另一步就不做,或者做了但最后恢復原樣。這件事就是一個事務處理。對于java 來說事務的類型有:JDBC事務、JTA(Java Transaction API)事務。
具體的話,可以去搜索引擎查看。目前在軟件開發中常用的SSH架構中 事務是由Spring來控制的。
Java 編程 ,事務管理的作用
寫了不少程序,Spring也經常用,每次用到數據庫時都會用Spring 事務管理,只知道用事務管理好,但現在還是不明白有什么作用,求高手解答啊事務就是對一系列的數據庫操作進行統一的提交或回滾操作,比如說做一個轉賬功能,要更改帳戶兩邊的數據,這時候就必須要用事務才能算是嚴謹的做法。要么成功,要么失敗,保持數據一致性。如果中間有一個操作出現異常,那么回滾之前的所有操作。
這樣有什么好處呢。
這樣可以防止在一些意外(例如說突然斷電)的情況下出現亂數據,防止數據庫數據出現問題。這邊加了錢,那邊卻還是一樣的數,這就完了。要是開放一個網上交易的平臺,這樣就會出大問題的!
還有其他的一些操作,像是要添加多條數據,如果程序要求必須全部正確才能插入的話,事務又起大作用了。
等等。。。開發中為了避免這種情況一般都會進行事務管理。
在JDBC中是通過Connection對象進行事務管理的,默認是自動提交事務,可以手工將自動提交關閉,通過commit方法進行提交,rollback方法進行回滾,如果不提交,則數據不會真正的插入到數據庫中。
Hibernate中是通過Transaction進行事務管理,處理方法與JDBC中類似。
Spring中也有自己的事務管理機制,使用TransactionMananger進行管理,可以通過Spring的注入來完成此功能。
Java種運用了大量的事務管理,就是對一系列的數據庫操作進行統一的提交或回滾操作,比如說做一個轉賬功能,要更改帳戶兩邊的數據,這時候就必須要用事務才能算是嚴謹的做法。要么成功,要么失敗,保持數據一致性。如果中間有一個操作出現異常,那么回滾之前的所有操作。
在strut2框架中為了避免多個用戶同時訪問服務器,都會使用事務管理來管理訪問的人數。
---------------------------------------------------------
這個問題我以前回答過別人的,請參考http://zhidao.baidu.com/question/191543132.html
有不明白的地方,直接百度HI 我吧
Spring提供的事務管理可以分為兩類:編程式的和聲明式的。
編程式的,比較靈活,但是代碼量大,存在重復的代碼比較多;聲明式的比編程式的更靈活方便。
1、傳統使用JDBC的事務管理
以往使用JDBC進行數據操作,使用DataSource,從數據源中得到Connection,我們知道數據源是線程安全的,而連接不是線程安全的,所以對每個請求都是從數據源中重新取出一個連接。一般的數據源由容器進行管理,包括連接池。例如TOMCAT,WEBSPHERE,WEBLOGIC等這些J2EE商業容器都提供了這個功能。
以往的我們使用JDBC在寫代碼時,事務管理可能會是這樣:
Connection conn = null;
try{
conn = DBConnectionFactory.getConnection;
conn.setAutoCommit(false);
//do something
conn.commit(); //commit transcation
}catch(Exception e){
conn.rollback();
}
finally{
try{
conn.close();
} catch(SQLException se){ //do sth.}
//close ResultSet,PreparedStatement,Connection
//notice:Maybe ocurr Exception when u close rs,pstmt,conn
}
按照以往的思路來寫代碼,代碼量比較長,而且容易疏忽,忘掉一些try/catch,引發一些異常無法catch,雖然有時候我們會寫DBTool類,來關閉這些資源,并且保證在關閉這些資源時,不向外拋異常,但是這樣做會導致額外的麻煩。
2、Spring提供的編程式的事務處理
Spring提供了幾個關于事務處理的類:TransactionDefinition //事務屬性定義
TranscationStatus //代表了當前的事務,可以提交,回滾。
PlatformTransactionManager這個是spring提供的用于管理事務的基礎接口,其下有一個實現的抽象類AbstractPlatformTransactionManager,我們使用的事務管理類例如DataSourceTransactionManager等都是這個類的子類。
我們使用編程式的事務管理流程可能如下:
(1) 聲明數據源。
(2) 聲明一個事務管理類,例如:DataSourceTransactionManager,HibernateTransactionManger,JTATransactionManager等
(3) 在我們的代碼中加入事務處理代碼:
TransactionDefinition td = new TransactionDefinition();
TransactionStatus ts = transactionManager.getTransaction(td);
try{
//do sth
transactionManager.commit(ts);
}catch(Exception e){transactionManager.rollback(ts);}
使用Spring提供的事務模板TransactionTemplate:
void add()
{
transactionTemplate.execute( new TransactionCallback(){
pulic Object doInTransaction(TransactionStatus ts)
{ //do sth}
}
}
TransactionTemplate也是為我們省去了部分事務提交、回滾代碼;定義事務模板時,需注入事務管理對象。
3、Spring聲明式事務處理
Spring聲明式事務處理也主要使用了IoC,AOP思想,提供了TransactionInterceptor攔截器和常用的代理類TransactionProxyFactoryBean,可以直接對組件進行事務代理。
使用TransactionInterceptor的步驟:
(1)定義數據源,事務管理類
(2)定義事務攔截器,例如:
<bean id =
Java中,在JAVA中處理數據庫事務的方法?
在java中 一般有兩種方式可以進行數據庫事務處理:
一是:如果你用到開源框架hibernater的話,在hibernater里面它提供了事務工廠,你可以利用這個類來進行事務操作。
二是:我們一般有Connection連接對象來對事務進行操作。
java.sql.*;庫里有啊
java事務處理有幾種方式
Atomic原子性、Consistency一致性、Isolation隔離性和Durability持久性。
原子性:指整個事務是不可以分割的工作單元。只有事務中所有的操作執行成功,才算整個事務成功,事務中任何一個SQL語句執行失敗,那么已經執行成功的SQL語句也必須撤銷,數據庫狀態應該回到執行事務前的狀態。
一致性:指數據庫事務不能破壞關系數據的完整性以及業務邏輯上的一致性。例如對于銀行轉賬事務,不管事務成功還是失敗,應該保證事務結束后兩個轉賬賬戶的存款總額是與轉賬前一致的。
隔離性:指的是在并發環境中,當不同的事務同時操縱相同的數據時,每個事務都有各自的完整數據空間。
持久性:指的是只要事務成功結束它對數據庫所做的更新就必須永久保存下來。即使發生系統崩潰,重新啟動數據庫系統后,數據庫還能恢復到事務成功結束時的狀態。
本文并不討論應該采用何種事務處理方式,主要目的是討論如何更為優雅地設計事務服務。僅以JDBC事務處理為例。涉及到的DAO,Factory,Proxy,Decorator等模式概念,請閱讀相關資料
相關推薦:
最高額保證法律依據(民法典后保證最高額擔保的規定)
中外合資經營企業的資本(中外合資企業注冊資本金要求)
車輛抵押貸款(汽車抵押貸款需要什么條件)
國有企業設立的資料(國有企業注冊條件)
怎么注冊公司流程(公司注冊流程及需要的材料)