JDBC中事务的使用
来源:互联网 发布:h5dm新域名 编辑:程序博客网 时间:2024/06/06 06:56
当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 if 和 case语句的使用
- grafana弱口令检测
- Unity中Input.GetAxis方法的返回值含义
- mysql去除重复记录
- 在Linux中让echo命令显示带颜色的字
- JDBC中事务的使用
- 应急资源管理系统方案
- .NET日期类型序列化后返回前台格式转换问题
- 写给java web一年左右工作经验的人
- 一篇故事讲述了计算机网络里的基本概念:网关,DHCP,IP寻址,ARP欺骗,路由,DDOS等
- 2017.5小结
- swift数组与集合所具有的方法
- Android 应用程序启动过程分析
- 历史进程图