JDBC中事务的使用
来源:互联网 发布:淘宝改宝贝标题 编辑:程序博客网 时间:2024/06/03 12:53
其中,银行转账这一事例,最能说明,使用事务的重要性了。
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使用事务隔离
- 页面自动跳转与http302、html refresh以及js跳转之间的关系
- 在Mac上安装cocoapods
- <iframe>标签自适应高度和宽度
- 一图看懂git
- Mac OS中显示与隐藏文件
- JDBC中事务的使用
- 数学的记号(notation)
- Android 弹出 Toast 时取消上一个 Toast(完美方案)增加同步
- Missing artifact com.sun:tools:jar:1.5.0解决办法
- JSON
- 存储方式二:文件(XML DOM解析)
- db2top工具详解[转]
- Ubuntu 截图工具
- sshpass: 用于非交互的ssh 密码验证