JDBC的事务控制和批量处理
一、事物的概念
所谓事务:是指一组原子操作(一组SQL语句执行)的工作单元。
将需要添加事务的代码放在try、catch块中:
try {
//需要添加事务的业务代码
} catch (SQLException e) {
...
}
在try块内添加提交操作,表示操作无异常,提交事务:conn.commit(); //正常流程,提交事务
在catch块内添加回滚事务,表示操作出现异常,撤消事务:conn.rollback(); //发生异常,撤消事务
Statement的execute()等方法一次只能执行一条SQL语句,如果同时有多条SQL语句要执行的话,可以使用addBatch()方法将要执行的SQL语句加入进来,然后执行executeBatch()方法,这样就可以在一次方法调用中执行多条SQL语句,以提高执行效率。
为了保证这一批语句要么全部成功,要么全部失败,应该把批处理放置在事务中进行。
使用PreparedStatement也可以进行批处理。
注意:批处理中执行的语句只能是更新语句(insert、delete、update),否则会抛出异常。