JDBC中事务的使用
来源:互联网 发布:集线器网络连接方式 编辑:程序博客网 时间:2024/06/03 16:25
当Jdbc程序向数据库获得一个Connection对象时,默认情况下这个Connection对象会自动向数据库提交在它上面发送的SQL语句。若想关闭这种默认提交方式,让多条SQL在一个事务中执行,并且保证这些语句是在同一时间共同执行的时,我们就应该为这多条语句定义一个事务。
其中,银行转账这一事例,最能说明,使用事务的重要性了。
update from account set money=money-100where name=‘a’;
update from account set money=money+100 wherename=‘b’;
因为这时,两个账户的增减变化是在一起执行的。现实生活中这种类似于同步通信的例子还有很多,这里,不再赘述。
当然,对于事务的编写,也是要遵守一定的顺序的:
首先,.设置事务的提交方式为非自动提交:
conn.setAutoCommit(false);
接下来,.将需要添加事务的代码放入try,catch块中。
然后,.在try块内添加事务的提交操作,表示操作无异常,提交事务。
conn.commit();
尤其不要忘记,.在catch块内添加回滚事务,表示操作出现异常,撤销事务:
conn.rollback();
最后,设置事务提交方式为自动提交:
conn.setAutoCommit(true);
这样,通过简单的几步,我们就可以完成对事务处理的编写了。
例:定义了一个事务方法并在方法内实现了语句之间的一致性操作
Connection con =null;
Statement st=null;
ResultSet rs=null;
PreparedStatement ps=null;
publicvoid startTransaction(){
con = DBCManager.getConnect();//获取连接对象
try {
//设置事务的提交方式为非自动提交:
con.setAutoCommit(false);
//将需要添加事务的代码一同放入try,catch块中
//创建执行语句
String sql ="delete from me where id = 7";
String sql1 = "update me set name ='chengong' ,age ='34' where id =4";
//分别执行事务
ps = con.prepareStatement(sql);
ps.executeUpdate();
ps = con.prepareStatement(sql1);
ps.executeUpdate();
//在try块内添加事务的提交操作,表示操作无异常,提交事务。
con.commit();
} catch (SQLException e) {
try {
//.在catch块内添加回滚事务,表示操作出现异常,撤销事务:
con.rollback();
} catch (SQLException e1) {
// TODO Auto-generatedcatch block
e1.printStackTrace();
}
e.printStackTrace();
}finally{
try {
//设置事务提交方式为自动提交:
con.setAutoCommit(true);
} catch (SQLException e) {
// TODO Auto-generatedcatch block
e.printStackTrace();
}
DBCManager.release(rs, ps, con);
}
}
- JDBC中事务的使用
- JDBC中事务的使用
- JDBC中事务的使用
- JDBC中事务的使用
- JDBC中事务的使用
- JDBC中事务的使用
- 在JDBC中使用事务
- mysql 事务处理,事务操作,JDBC中事务的使用,事务的sql语句,
- JDBC中使用事务编程步骤
- 在spring中使用JDBC事务配置
- JDBC中关于事务的设置
- JDBC中对事务的支持
- JDBC中事务的整个流程!
- Java中JDBC的事务问题
- Jdbc中事务的保存点解析
- Spring-jdbc:事务管理器的使用
- 在Java的JDBC使用中设置事务回滚的保存点的方法
- jdbc使用事务隔离
- oracle drop表空间
- IOC原理分析
- Oracle:PL/SQL--打开控制台or关闭控制台
- MySQL 5.7.14安装配置教程
- 字符串动规一例
- JDBC中事务的使用
- 安卓谷歌地图开发
- cocos 2dx 3.12 学习笔记(三) TouchTest
- HTML 页面加载和解析流程详细介绍
- 一个Linux虚拟机上Oracle数据库磁盘空间不足的解决办法
- noip2014解方程题解
- swift视图与控制器之间的简单传值
- tomcat集群
- 【华为OJ】字符逆序