首页 > 编程 > .NET > 正文

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

2024-07-10 13:03:25
字体:
来源:转载
供稿:网友
事务在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 支持,但是你不能实施它们对于当前的oracle数据提供者版本来说.事务于oracle 来说或者回滚或者提交,局部回滚是不能的.



发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表