jdbc批处理与事务处理

批处理,英文叫 Batch,顾名思义就是成批地处理某些事务。对于频繁访问数据库的程序而言,选择批处理是最合适不过的了。本文将介绍如何利用 JDBC 实现批处理。


一、什么是批处理

          屁处理是指一次性执行多条SQL语句,并且在执行过程中,如果某条语句出现错误,则仅停止该错误语句的执行,而批处理中其他所有语句则继续执行。这是有别与事务处理 (事务处理的详情参见《JDBC进阶之事务处理基本原理及示例》) 的,事务处理一旦出现错误,则全部都取消执行并进行回滚。

          JDBC API 中提供了批处理的机制,可以让 Statement 同时执行多个 SQL 语句,以提高操作数据库的性能。


二、利用JDBC 实现批处理的基本步骤

          1)创建 Connection 对象,利用 Connection 对象创建 Statement 对象;

          2)判断是否支持批处理;

          3)取消 Connection 对象的自动提交模式;【可以取消,这步没啥意义】

          4)使用 Statement 对象的增加批处理语句的 addBatch() 方法;

          5)使用 Statement 对象执行批处理的 executeBatch() 方法批处理执行多条添加到 Statement 对象中的 SQL 语句;

          6)关闭连接;





  事务处理是在针对数据库操作时一个重要环节,它可以保证执行多条记录的一致性,实现数据库中表与表之间的关联,同时提高了对数据操作的准确性、安全性。本文主要一起来学习在Java程序中如何使用JDBC来实现数据间的事务处理。


一、什么是事务处理

         事务处理就是当执行多个SQL指令时,如果因为某个原因使其中一条指令执行有错误,则取消先前执行过的所有指令。它的作用是保证各项操作的一致性和完整性。【事物回到原来的状态】


二、JDBC中的事务控制

        JDBC API中的JDBC事务是通过Connection对象进行控制的。Connection对象提供了两种事务模式:自动提交模式和手工提交模式。系统默认为自动提交模式,即,对数据库进行操作的每一条记录,都被看作是一项事务。操作成功后,系统会自动提交,否则自动取消事务。 如果想对多个SQL进行统一的事务处理,就必须先取消自动提交模式,通过使用Connection 的setAutoCommit(false) 方法来取消自动提交事务。Connection类中还提供了如下其他控制事务的方法:

        1)public boolean getAutoCommit():判断当前事务模式是否为自动提交,如果是则返回ture,否则返回false;

        2)public void commit():提交事务;

        3)public void rollback():回滚事务;

注意:

        Java中使用JDBC事务处理,一个JDBC不能跨越多个数据库而且需要判断当前使用的数据库是否支持事务。这时可以使用 DatabaseMedaData 的supportTranslations() 方法进行检查数据库是否支持事务处理,若返回 true 则说明支持事务处理,否则返回 false 。如使用MySQL 的事务功能,就要求MySQL里的表的类型为Innodb才支持事务控制处理,否则,在Java程序中做了 commit 或 rollback ,但数据库中是不生效的。


三、JDBC 事务处理基本流程


       实现事务处理的基本流程如下:

        1)判断当前使用的JDBC驱动程序和数据库是否支持事务处理;

        2)在支持事务处理的前提下,取消系统自动提交模式;

        3)添加需要进行的事务信息;

        4)将事务处理提交到数据库;

        5)在处理事务时,若某条信息发生错误,则执行事务回滚操作,并回滚到事务提交前的状态。


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值