执行多条语句事务处理
来源:互联网 发布:矢量图标js下载 编辑:程序博客网 时间:2024/05/29 16:40
当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);
}
}
- 执行多条语句事务处理
- (C#)执行多条SQL语句,事务处理
- oracle事务处理多条sql语句
- if执行多条语句....
- 执行多条 sql语句
- 使用事务处理多条SQL语句时,@@error在捣鬼
- java批量执行多条Sql语句
- mysqli->multi_query()执行多条语句
- * 执行多条更新的Sql语句
- 一次性执行多条SQL语句
- ADO执行多条sql语句
- shell Learning [case3 执行多条语句]
- .java 执行多条 sql 语句
- PLSQL同时执行多条语句实例
- SqlCommand可以执行多条语句
- PHP学习 mysqli执行多条语句
- 同时执行多条sql语句
- mysql执行多条语句建表
- Python 2 和 Python 3 的区别和比较
- [debug] debugging in python with pdb
- myeclipse10破解 run.bat文件打不开、闪退问题
- 经典算法题每日演练——第六题 协同推荐SlopeOne 算法
- 深入理解C#中的泛型(二)
- 执行多条语句事务处理
- NC是空脚,它的作用是什么呢?
- java indexof 与split
- 野指针
- 简介servlet
- hihoCoder_1053_居民迁移(二分+贪心)
- 基于Linux流量控制系统功能简介
- 经典算法题每日演练——第七题 KMP算法
- 淘宝新举动——屏幕跟随购物车按钮啦