在ADO.NET中使用事务保护数据的完整性(3)

** 事务在 ADO.Net 中 **

Ado.net 支持两种事务模型,这在.Net Framework 文档中作为指南有定义.事务指南手册介绍了通常应该知道的数据库事务, 它影响操作单个目标数据库.一个类通过由 ado.net 显示描述的事务边界使用事务类和方法能提供事务指南.在接下来的章节中,我将把重点放在事务指南上.

自动事务也是可行的,为了使用类来参与事务来协调跨多个数据源的改变.在这种情景下事务本身是在外层处理的,比如通过 com+ 和 DTC . 需要了解更多自动事务的,可以参照相关自动事务.

注:当没有在你的代码中指定事务行为时,你应该注意数据库事务默认行为.比如, sql Server 默认自动模式,每个事务 -Sql 语句或成功或失败.要了解哪种默认行为是希望得到的从你工作的数据源中,能帮你决定你是否显示定义事务,也可以对于你理解你的系统行为更有帮助.

** 事务相关类总揽 **

Ado.net 数据提供对象通过 Connection, Command, 和 Transaction 类来提供事务功能. 一个典型的事务过程类似以下:

1. 打开事务通过 Connetion.BeginTransaction()

2. 通过设置 Command 的 Command.Transaction 属性,在事务中加入语句或存储过程.

3. 依靠提供者,选择使用 Transaction.Save() 或 Transaction.Begin() 来创建 savepoint 或内嵌的事务来使能局部回滚.

4. 提交或回滚事务通过使用 Transaction.Commit() 或 Transaction.Rollback()

所有的数据提供者提供了同样的基本结构来处理事务,开始连接的事务,加入指令,使用事务物件来提交或回滚.

** Sql Server 事务 **

Sql Server 数据提供对象提供事务的基本功能情况见以下的类和成员:

** Class **

|

** Member **

|

** Function **

---|---|---

SqlConnection

|

BeginTransaction

|

Open a new transaction.

SqlCommand

|

Transaction

|

Enlist the command associated with the object in an open transaction.

SqlTransaction

|

Save

|

Create a savepoint to enable a partial rollback.

SqlTransaction

|

Rollback

|

Roll back a transaction.

SqlTransaction

|

Commit

|

Commit a Transaction

Sql Server 数据提供者( 对于 Sql Server 来说, OLE DB provider 也是如此) 不提供在代码中创建内嵌事务的方式, 因此内嵌事务在 Sql Server 并不真正的被支持.因此这儿只有一种方式来开始一个事务在 SqlClient 中-使用 SqlConnection.BeginTransaction(). 你不能在统一个连接中打开另外一个事务,直到先前的事务被提交或回滚,因此在任何时间每个连接只有一个打开的事务.为了使用局部回滚,使用 SqlTransaction.Save().

** OLE DB ** ** 事务 **

OLE DB 数据提供者提供事务的基本功能情况见以下的类和成员:

**

** Class **

|

** Member **

|

** Function **

---|---|---

OleDbConnection

|

BeginTransaction

|

Open a new transaction.

OleDbCommand

|

Transaction

|

Enlist the command associated with the object in an open transaction.

OleDbTransaction

|

Begin

|

Create a nested transaction, to enable a partial rollback.

OleDbTransaction

|

Rollback

|

Roll back a transaction.

OleDbTransaction

|

Commit

|

Commit a Transaction

OLE DB 数据提供者不提供任何的方法来设置 savepoints, 相反的有个 Begin() 方法在 OleDbTransaction 物件上.这允许你创建内嵌事务(根据你的数据库)来提供类似的功能.在这种情况下你可以在单个连接中拥有多个事务.但必须记住的是显示的调用提交和回滚.

记住, .NET OLE DB 数据提供者的内嵌事务依赖于你的数据库和指定的 OLE DB 提供者.为了成功实施内嵌事务,其必须被你的数据库和 OLE DB 提供者都支持.

Oracle 事务

Oracle 数据提供者提供事务的基本功能情况见以下的类和成员:

**Class **

|

** Member **

|

** Function **

---|---|---

** OracleConnection **

|

BeginTransaction

|

Open a new transaction.

** OracleCommand **

|

Transaction

|

Enlist the command associated with the object in an open transaction.

** OracleTransaction **

|

Rollback

|

Roll back a transaction.

** OracleTransaction **

|

Commit

|

Commit a Transaction

Oracle 数据提供者不允许你指定 savepoints 或内嵌事务. Savepoints 被 Oracle <SPAN style="FONT-SIZE: 8pt; COLOR: black; FONT-FAMILY:

**

Published At
Categories with Web编程
Tagged with
comments powered by Disqus