概述
事务处理是在针对数据库操作时一个重要环节,它可以保证执行多条记录的一致性,实现数据库中表与表之间的关联,同时提高了对数据操作的准确性、安全性。本文主要一起来学习在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)在处理事务时,若某条信息发生错误,则执行事务回滚操作,并回滚到事务提交前的状态。
最后
以上就是激昂冬天为你收集整理的JDBC事务的全部内容,希望文章能够帮你解决JDBC事务所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复