** 事务在 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:
**