java的事务处理,是这么一回事,如果对数据库进行多次操作,每一次的执行或步骤都是一个事务.如果数据库操作在某一步没有执行或出现异常而导致事务失败,这样有的事务被执行有的就没有被执行,从而就有了事务的回滚,取消先前的操作.....
JavaBean中使用JDBC方式进行事务处理
public int delete(int sID) {
dbc = new DataBaseConnection();
Connection con = dbc.getConnection();
try {
con.setAutoCommit(false);// 更改JDBC事务的默认提交方式
dbc.executeUpdate("delete from xiao where ID=" + sID);
dbc.executeUpdate("delete from xiao_content where ID=" + sID);
dbc.executeUpdate("delete from xiao_affix where bylawid=" + sID);
con.commit();//提交JDBC事务
con.setAutoCommit(true);// 恢复JDBC事务的默认提交方式
dbc.close();
return 1;
}
catch (Exception exc) {
con.rollBack();//回滚JDBC事务
exc.printStackTrace();
dbc.close();
return -1;
}
}
在数据库操作中,一项事务是指由一条或多条对数据库更新的sql语句所组成的一个不可分割的工作单元。只有当事务中的所有操作都正常完成了,整个事务才能被提交到数据库,如果有一项操作没有完成,就必须撤消整个事务。
例如在银行的转帐事务中,假定张三从自己的帐号上把1000元转到李四的帐号上,相关的sql语句如下:
update account set monery=monery-1000 where name='zhangsan'
update account set monery=monery+1000 where name='lisi'
这个两条语句必须作为一个完成的事务来处理。只有当两条都成功执行了,才能提交这个事务。如果有一句失败,整个事务必须撤消。
在connection类中提供了3个控制事务的方法:
(1) setAutoCommit(Boolean autoCommit):设置是否自动提交事务;
(2) commit();提交事务;
(3) rollback();撤消事务;
在jdbc api中,默认的情况为自动提交事务,也就是说,每一条对数据库的更新的sql语句代表一项事务,操作成功后,系统自动调用commit()来提交,否则将调用rollback()来撤消事务。
在jdbc api中,可以通过调用setAutoCommit(false) 来禁止自动提交事务。然后就可以把多条更新数据库的sql语句做为一个事务,在所有操作完成之后,调用commit()来进行整体提交。倘若其中一项sql操作失败,就不会执行commit()方法,而是产生相应的sqlexception,此时就可以捕获异常代码块中调用rollback()方法撤消事务。
此文转于:http://hi.baidu.com/vjame/blog/item/16ab3801cbf93d0a7aec2c69.html
分享到:
- 2008-03-06 09:41
- 浏览 1318
- 评论(0)
- 论坛回复 / 浏览 (0 / 3615)
- 查看更多
相关推荐
在JDBC中,打开一个连接对象Connection时,缺省是auto-commit模式,每个SQL语句都被当作一个事务,即每次执行一个语句,都会自动的得到事务确认。为了能将多个SQL语句组合成一个事务,要将auto-commit模式屏蔽掉。在...
- **原子性(Atomicity)**:事务中的所有操作要么全部完成,要么全部不完成,不存在部分执行的情况。 - **一致性(Consistency)**:事务完成后,系统状态将从一个一致状态转换到另一个一致状态。 - **隔离性...
Java分布式事务是大型分布式系统中不可或缺的一个重要组成部分,它确保在多个网络节点间的数据操作能够保持一致性和完整性。在分布式环境中,由于多个服务之间可能存在数据交互,因此需要一种机制来处理跨服务的数据...
1. **原子性**:一个事务中的所有操作被视为一个整体,要么全部完成,要么全部回滚,不会出现部分完成的情况。 2. **一致性**:事务完成后,系统状态必须保持一致,即事务执行前后的数据库状态应满足所有的业务规则...
1. **原子性**:事务中的每个操作要么全部完成,要么全部不完成。如果在事务执行过程中发生错误,所有已完成的操作都会被回滚,确保数据库状态不变。 2. **一致性**:事务结束后,数据库必须处于一致状态,即事务...
### 开发中的Java中的事务管理 #### 一、引言 在Java开发中,事务管理是确保数据一致性和完整性的重要手段。特别是在涉及多个数据库操作时,如果这些操作不能作为一个整体成功执行,则整个事务应被回滚,以保持...
Java事务处理详解 Java事务处理是指在Java应用程序中对事务的管理和控制。事务是指一系列的操作,Either all succeed or all fail。Java事务处理的目的是为了确保数据的一致性和完整性。 Spring是Java事务处理的...
此外,Oracle数据库支持事务的保存点(SAVEPOINT),这是一种在事务中设置的标记,允许在回滚时只回滚到保存点,而不是整个事务。这在需要部分撤销操作但又不想完全回滚事务的情况下非常有用。 总的来说,Oracle在...
【Java事务管理】Java事务管理是确保数据一致性的重要机制,主要涉及事务的概念、特性、以及在不同环境下的实现方式。事务是一组操作,遵循原子性、一致性、隔离性和持久性的原则,简称为ACID特性: 1. **原子性...
java代码-使用java解决数据库事务处理的源代码 ——学习参考资料:仅用于个人学习使用!
### Java事务处理总结 #### 一、什么是Java事务 事务是指一组操作的集合,这些操作要么全部成功,要么全部失败,以确保数据的一致性和完整性。在Java开发中,事务处理主要关注的是如何管理和控制对数据库的操作,...
当我们谈论"Java事务"时,我们通常指的是在多条SQL语句执行过程中保持数据完整性的一种方法。以下是一个简化的Java事务处理代码示例,适用于初学者理解和学习。 首先,我们需要了解Java中的JDBC(Java Database ...
Java事务管理是数据库操作中的关键部分,用于确保数据的一致性和完整性。在Java中,我们主要通过Java Database Connectivity (JDBC) API来处理事务。"java事务 - 传递Connection"这个主题聚焦于如何通过共享同一`...
Java事务和ThreadLocal是两种在Java编程中至关重要的概念,它们分别用于处理多线程环境下的数据一致性问题和提供线程局部变量。 首先,我们来深入理解Java事务。在数据库操作中,事务是一系列操作的集合,这些操作...
- **原子性(Atomicity)**:事务中的所有操作要么全部完成,要么全部不完成,不会出现部分执行的情况。 - **一致性(Consistency)**:事务完成后,数据库必须处于一个一致的状态,即事务前后的数据规则保持不变...
如果事务中的任何步骤失败,所有更改都将被回滚,就像它们从未发生过一样。在上述示例中,如果删除操作只执行了一部分,剩余部分失败,事务会回滚以保持数据库的一致状态。 2. 一致性:事务完成后,数据必须处于...
- **原子性(Atomicity)**:事务中的所有操作被视为一个不可分割的工作单元,要么全部执行成功,要么全部失败。 - **一致性(Consistency)**:事务的执行必须使数据库从一个一致性的状态转换到另一个一致性的...