关于java的事务处理和举例
来源:互联网 发布:易语言源码网站 编辑:程序博客网 时间:2024/04/25 19:37
csdn(日后再说)
conn.setAutoCommit(false);
conn.commit();
conn.setAutoCommit(true);
conn.rollback();
就这么多,很好用的,比写到存储过程中好啊。
还可以嵌套使用。
eg
=========================================================
Class.forName("com.microsoft.jdbc.sqlserver.SQLServerDriver");
Connection conn=DriverManager.getConnection
("jdbc:microsoft:sqlserver://localhost:1433;User=sa;password=;DatabaseName=softeem");
Statement s=conn.createStatement();
conn.setAutoCommit(false);
ResultSet results=statement.executeQuery(SQL);
{处理过程;
conn.commit();}
conn.setAutoCommit(true);
try{
}
catch{
conn.rollback()
}
Conn.close();
解释:
=========================================================
···········经典。经典。············
=========================================================
jdbc的commit和rollback
commit和rollback是数据库事务的两个概念。
一个数据库事务有开始和结束边界(boundary), 位于boundary的对数据库的各种操作认为是对该事务的操作。
一个事务的要占用数据库的一些资源,比如可能获得数据库的某个表的某条记录的lock,如果一个事务长期占用资源而不去释放,那么对其他的事务是不利的,可能会使得速度很慢。
所以对数据库操作的正确做法是让事务短小,只做一些应该在事务里边做的事情,以最快的速度让一个事务结束,从而释放该事务所占有的资源。
如何让一个事务结束?commit或者rollback。两者选其一,而且必选其一,才能够确保一个事务被可靠的,安全的终止。commit意味着对事务中的操作确定,rollback意味着对事务中的操作否定。
JDBC中如何正确的处理事务?
1。如果需要保持一些操作的原子性,比如转帐就需要原子性,那么必须要将这些操作放在一个事务中。
Connection conn = 。。。;
conn.setAutoCommit(false);
//从一个人那里扣钱
//往另一个人那里加钱
//做一些其他的事情,比如通过jms来广播一条成功的消息
conn.commit();
上面的代码看起来似乎完成了转帐的操作,其实需要的改进的地方很多。
1)不能保证上面的事务能够可靠的终止。
如果对数据库的扣钱,加钱操作失败,那么conn.commit()不会被执行。
2)通过jms来广播消息动作跟这个事务没有太大的关系,所以不应该放在事务中。试想如果jms广播需要花5s的时间,那么该事务结束的时间就要推迟5s,释放lock的时间也要被推迟5s!
正确的代码:
Connection conn = 。。。;
boolean success = false;
try{
conn.setAutoCommit(false);
//从一个人那里扣钱
//往另一个人那里加钱
conn.commit();
success = true;
}
catch(SQLException e){
conn.rollback();
success = false;
}
if(success)//做一些其他的事情,比如通过jms来广播一条成功的消息
2。如果不需要处理原子性的操作,比如查询,那么只需要conn.setAutoCommit(true);做就可以了。
- 关于java的事务处理和举例
- 关于jdbc的模块化和事务处理
- 关于数据库的事务处理
- java和ibatis事务处理
- java的事务处理
- Java的事务处理
- Java 的 SQL 事务处理
- Java的事务处理
- Java的数据库事务处理
- [转]java的事务处理
- Java的事务处理
- 关于spring,IOC和AOP的解析原理和举例
- 关于spring,IOC和AOP的解析原理和举例
- 关于spring,IOC和AOP的解析原理和举例
- 关于spring IOC和AOP的解析原理和举例
- 关于spring,IOC和AOP的解析原理和举例
- JAVA关于变量的存储位置举例验证
- 关于Patch应用和举例
- helix server介绍及架设网络电视
- string to float
- 1.1.1. Where Do Streams Come From?
- windows2003优化小贴士
- 数据库设计
- 关于java的事务处理和举例
- 闲置了好久
- oracle中的函数据
- java 数据库 连接池
- .Net 使用 Intercom OP 调用 Excel 实现报表
- eclipse提示JVM版本太低
- 人工智能http://cai.csu.edu.cn/jpkc/rengongzhineng/Index.htm
- VC2005的IntelliSense高CPU占用问题
- [ztjSQL]CAST 和 CONVERT