为了保证数据库中数据的一致性,数据的操作应当是离散的成组的逻辑单元。当它全部完成时,数据的一致性可以保持,而当这个单元中的一部分操作失败,整个事务应当全部视为错误,所有从起始点以后的操作应全部回退到开始状态。
事务的操作: 先定义开始一个事务,然后对数据做修改操作,这时如果提交(commit),这些数据就永久的保存下来,如果回退(rollback),数据库管理系统就放弃所有的修改而回到开始事务的状态。
(1)原子性(Atmicity)
原子性是指事务是一个不可分割的工作单位,事务的操作要么都发生,要么都不发生。
(2)一致性(Consistency)
事务必须使数据库从一个一致性状态变换到另外一个一致性的状态。
(3)隔离性(Isolation)
事务的隔离性是指一个事务的执行不能被其他事务干扰,即一个事务内部操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。
(4)持久性(Durability)
持久性是一个事务一旦被提交,它对数据库中的数据改变就是永久性的,接下来的其他操作和数据库故障不应该对其有任何影响。
(1)如果多个操作,每个操作使用的是自己的单独连接,则无法保证事务。
(2)使用步骤:
A: 事务开始前,开始事务,即取消自动提交。con.setAutoCommit(false);
B: 如果事务的操作都成功,就提交事务。con.commit();
C: 如果出现异常,在Catch块中回滚事务。con.rollback();
/*
* 事务
* 1.如果多个操作,每个操作使用的是自己的单独连接,则无法保证事务。
* 2.步骤
* (1)事务开始前,开始事务,即取消自动提交。
* con.setAutoCommit(false);
* (2)如果事务的操作都成功则提交事务
* con.commit();
* (3)回滚事务: 如出现异常,在catch块中回滚事务。
* con.rollback();
*/
@Test
public void testTx(){
Connection con = null;
try{
//保证连接是唯一的,传入相同的Connnection
con = JdbcTools.getConnection();
//开始事务:取消默认提交
con.setAutoCommit(false);
String sql = "update person set salary = salary - 500 where name = ?";
JdbcTools.update(con,sql,"Tom");
int i = 1 / 0;
String sql2 = "update person set salary = salary + 500 where name = ?";
JdbcTools.update(con,sql2,"Jerry");
//正常就提交事务
con.commit();
}catch(Exception e){
e.printStackTrace();
//出现异常就回滚事务
try{
con.rollback();
}catch(SQLException e1){
e1.printStackTrace();
}
}
finally{
JdbcTools.releaseResource(con,null,null);
}
}原文:http://www.cnblogs.com/yangang2013/p/5406152.html