Java JDBC 理论笔记(三)

原:http://hi.baidu.com/zero_spy/ 2011-11-05

 

五、JDBC事务

1、 事务介绍 

事务是一步或多步组成操作序列组成的逻辑执行单元,这个序列要么全部执行,要么则全部放弃执行。事务的四个特性:原子性(Atomicity)、一致性(Consistency)、隔离性(IsoIation)和持续性(Durability)

原子性(Atomicity):事务应用最小的执行单元,不可再分。是事务中不可再分的最小逻辑执行体。 

一致性(Consistency):事务的执行结果,必须使数据库的从一个一致性的状态变到另一个一致性的状态。 

隔离线(IsoIation):各个事务的执行互不干扰,任意一个事务的内部操作对其他并发的事务,都是隔离的。也就是:并发执行的事务之间不能看到对方的中间状态,并发执行的事务之间不能互相影响。 

持续性(Durability):持续性也称为持久性(Persistence),指事务一旦提交,对数据所做的任何改变,都要记录到永久存储器中,通常就是保存在物理数据库中。 

通常数据库的事务涉及到的语句有:一组DML(Data Munipulation Language,数据操作语言)语句,这组DML语句修改后数据将保持较好的一致性;    操作表的语句,如插入、修改、删除等;一个DDL(Data Definition Language,数据定义语言)语句,操作数据对象的语言,有create、alter、drop。一个DCL(Data Control Language,数据控制语言)语句,主要有grant、revoke语句。 DDL和DCL语句最多只能有一个,因为它们都会导致事务的立即提交。当事务所包含的全部数据库操作都成功执行后,应该提交事务,使这些修改永久生效。事务提交有两种方式:显示提交和自动提交。显示提交:使用commit提交自动提交:执行DLL或DCL,或者程序正常退出 当事务包含的任意一个数据库操作执行失败后,应该回滚(rollback)事务,使该事务中所作的修改全部失效。事务的回滚方式有两种:显示回滚和自动回滚。显示回滚:使用rollback自动回滚:系统错误或强行退出

2、 JDBC的事物的支持 

JDBC的Connection也支持事物,Connection默认打开自动提交,即关闭事物。也就是说,每条SQL语句执行就会立即提交到数据库,永久生效,无法对其进行操作。关闭Connection的自动提交,开启事物。Connection的setAutoCommit方法即可:connection.setAutoCommit(false);通过connection.getAutoCommit()来获取事物的模式。当我们开启事物后,在当前Connection中完成的数据库操作,都不会立即提交到数据库,需要调用Connection的commit方法才行。如果有语句执行失败,可以调用rollback来回滚。注意:如果Connection遇到未处理的SQLException异常时,系统将非正常退出,系统会自动回滚该事务。如果程序捕捉了该异常,则需要在异常处理中显示回滚事务。 Connection提供了设置事务中间保存点的方法:setSavepoint,有2个方法可以设置中间点:Savepoint setSavepoint():在当前事务中创建一个未命名的中间点,并返回该中间点的Savepoint对象。Savepoint setSavepoint(String name):当前事务中创建一个具有指定名称的中间点,并返回该中间点的Savepoint对象通常setSavepoint(String name)设置中间点的名称,事务回滚并不是通过中间点的名称进行回滚的,而是根据中间点对象进行回滚的。设置名称只是更好的区分中间点对象,用Connection的rollback(Savepoint savepoint)方法即可完成回滚到指定中间点。

  

3、 JDBC的批量更新 

批量更新就是可以同时进行多条SQL语句,将会被作为一批操作被同时执行、同时提交。批量更新需要得到数据底层的支持,可以通过调研DataBaseMetaData的supportsBatchUpdates方法来查看底层数据库是否支持批量更新。批量更新也需要创建一个Statement对象,然后通过该对象的addBatch方法将多条SQL语句同时收集在一起,然后通过Statement对象的executeBatch同时执行这些SQL语句,如下代码:Statement sm = conn.createStatement();sm.addBatch(sql);sm.addBatch(sql2);sm.addBatch(sql3);…//同时执行多条SQL语句sm.executeBatch();执行executeBatch将返回一个int[]的数组,因为使用Statement执行DDL、DML都将返回一个int的值,而执行多条DDL、DML也将返回一个int数组。批量更新中不允许出现select查询语句,一旦出现程序将出现异常。如果要批量更新正确、批量完成,需要用单个事务,如果批量更新过程中有失败,则需要用事务回滚到原始状态。如果要达到这样的效果,需要关闭事务的自动提交,当批量更新完成再提交事务,如果出现异常将回滚事务。然后将连接恢复成自动提交模式。publicint[] executeBatch(String[] sql) throws SQLException {int[] result = null;    conn = DBHelper.getConnection();try {//获得当前Connection的提交模式boolean autoCommit = conn.getAutoCommit();//关闭自动提交模式        conn.setAutoCommit(false);        sm = conn.createStatement();for (String s : sql) {            sm.addBatch(s);        }//执行批量更新        result = sm.executeBatch();//提交事务        conn.commit();//还原提交模式        conn.setAutoCommit(autoCommit);    } catch (Exception e) {        e.printStackTrace();        conn.rollback();    } finally {if (sm != null) {            sm.close();        }        DBHelper.close();    }return result;}六、分析数据库数据

1、 使用DatabaseMetaData分析数据库数据 

JDBC提供了DatabaseMetaData来封装数据库连接对应的数据库信息,通过Connection的getMetaData方法来获取该对象。DatabaseMetaData接口通常数据库驱动提供商完成实现,其作用是让用户了解数据库的底层信息。使用该接口可以了解数据库底层的实现,便于完成多个数据库的相互切换。如:可以利用supportsCorrelatedSubquenes方法来查看数据库底层是否可以利用关联子查询,或是调用supportsBatchUpdates方法查看是否支持批量更新。大部分的DatabaseMetaData都是以ResultSet对象返回的,可以通过ResultSet对象的getString、getInt来获取相关信息。DatabaseMetaData方法都需要传递一个xxxPattern的模式字符串,这个字符串是过滤条件,一般传递是SQL中的%、_等内容。

如果传递一个null表示不作任何过滤。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值