您的位置:首页 > 其它

9-15课堂笔记JDBC的事务控制和批量处理

2011-09-15 20:43 267 查看
JDBC的事务控制和批量处理
所谓事务:是指一组原子操作(一组SQL语句执行)的工作单元

这个工作单元中的所有原子操作在进行期间,与其他事务隔离,免于因数据来源的交相更新而发生混乱,事务中的所有原子操作要么全部执行成功,要么全部失败。

创建JDBC的事务主要分以下步骤:

1.设置事务的提交方式为非自动提交:conn.setAutoCommit(false);

2. 将需要添加事务的代码放在try、catch块中:

try {

//需要添加事务的业务代码

} catch (SQLException e) {

...

}

3.在try块内添加提交操作,表示操作无异常,提交事务:conn.commit(); //正常流程,提交事务

4.在catch块内添加回滚事务,表示操作出现异常,撤消事务:conn.rollback(); //发生异常,撤消事务

5.设置事务提交方式为自动提交:conn.setAutoCommit(true); //自动提交事务

JDBC批量处理

1. Statement的execute()等方法一次只能执行一条SQL语句,如果同时有多条SQL语句要执行的话,可以使用addBatch()方法将要执行的SQL语句加入进来,然后执行executeBatch()方法,这样就可以在一次方法调用中执行多条SQL语句,以提高执行效率。

2.为了保证这一批语句要么全部成功,要么全部失败,应该把批处理放置在事务中进行。

3.使用PreparedStatement也可以进行批处理。

注意:批处理中执行的语句只能是更新语句(insert、delete、update),否则会抛出异常

4. 简单地说,JDBC可做三件事:与数据库建立连接、发送 SQL 语句并处理结果。接下来通过几个简单的示例演示JDBC的应用。

对JDBC操作数据库的工具类的封装

一. 对获得Connection对象进行封装

1.将数据库的配置信息写到一个属性文件中,然后用IO流去获取,当需要修改数据库连接的时候只要改动配置文件即可。

2.在src下新建属性文件jdbc.properties,添加如下内容:

driver=com.mysql.jdbc.Driver

url=jdbc:mysql://localhost:3306/test

username=root

二. 对关闭JDBC资源类的封装

1.新建DbClose.java类,添加方法关闭结果集对象、语句对象、连接对象。

2.在执行增加、删除、修改的时候可以使用代码关闭连接:DbClose.close(Statement stmt, Connection conn);

3.在执行查询之后使用如下代码关闭连接:DbClose.close(ResultSet rs, Statement stmt, Connection conn);

4.password=root

三.对关闭JDBC资源类的封装

1.新建DbClose.java类,添加方法关闭结果集对象、语句对象、连接对象。

2.在执行增加、删除、修改的时候可以使用代码关闭连接:DbClose.close(Statement stmt, Connection conn);

3.在执行查询之后使用如下代码关闭连接:DbClose.close(ResultSet rs, Statement stmt, Connection conn);

四. 对执行数据库操作类的封装

在一个程序中会有很多地方要操作数据库,那么对执行数据库操作同样需要修改。

隔离级别

尽管可串行性对于事务确保数据库中的数据在所有时间内的正确性相当重要,然而许多事务并不总是需求完全的隔离。例如,多个作者工作于同一本书的不同章节。新章节能在任意时候提交到项目中。不过,对于已编辑过的章节,没有编辑人员的批准,作者不能对此章节进行所有更改。这样,尽管有未编辑的新章节,但编辑人员仍能确保在任意时间该书籍项目的正确性。编辑人员能查看以前编辑的章节及最近提交的章节。

事务准备接受不一致数据的级别称为隔离级别。隔离级别是个事务必须和其他事务进行隔离的程度。较低的隔离级别能增加并发,但代价是降低数据的正确性。相反,较高的隔离级别能确保数据的正确性,但可能对并发产生负面影响。

sql-92 定义了下列四种隔离级别:

Ø 未提交读(事务隔离的最低级别,仅可确保不读取物理损坏的数据)。

Ø 提交读(sql server 默认级别)。

Ø 可重复读。

Ø 可串行读(事务隔离的最高级别,事务之间完全隔离)。

如果事务在可串行读隔离级别上运行,则能确保所有并发重叠事务均是串行的。

下面四种隔离级别允许不同类型的行为。如表所示:

隔离级别

脏读
不可重复读
幻读
未提交读



提交读



可重复读



可串行读



事务必须运行于可重复读或更高的隔离级别以防止丢失更新。当两个事务检索相同的行,然后基于原检索的值对行进行更新时,会发生丢失更新。如果两个事务使用一个 update 语句更新行,并且不基于以前检索的值进行更新,则在默认的提交读隔离级别不会发生丢失更新。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: