📄 100165598.htm
字号:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><title>
21.2.2 事务处理
</title></head>
<body>
<div class="area">
<div class="col1">
<div class="lineBlue">
</div>
<!-- title -->
<div class="arcTitle">
<h1>
<a href="../16">
C#高级编程(第3版)
</a>
</h1>
<div style="text-align: center; font-size: 15px">
<a href="100165598.htm">
21.2.2 事务处理
</a>
</div>
<div style="text-align: center; font-size: 15px">
<a class="url" href="../../default.htm">http://book.csdn.net/</a>
2006-10-13 14:41:00
</div>
<div style="margin: 0px auto; width: 700px; border: solid 1px #0b5f98;">
<div style="float: left; width: 16px; background-color: #0b5f98; color: White; padding: 1px;">
图书导读
</div>
<div style="float: right; width: 670px; text-align: left; line-height: 16pt; padding-left: 2px">
<!--导读-->
<h1 id="divCurrentNode" style="color: #b83507; width: 100%; text-align: left; font-size: 12px; padding-left: 2px">当前章节:<a href='100165598.htm'><font color='red'>21.2.2 事务处理</font></a></h1>
<div id="divRelateNode" style="padding-left: 2px">
<div style='float:left;width:49%'>·<a href='100165595.htm'>21.1.3 数据库特定的类</a></div><div style='float:right;width:49%'>·<a href='100165596.htm'>21.2 使用数据库连接</a></div><div style='float:left;width:49%'>·<a href='100165597.htm'>21.2.1 高效地使用连接</a></div><div style='float:right;width:49%'>·<a href='100165599.htm'>21.3 命令</a></div><div style='float:left;width:49%'>·<a href='100165600.htm'>21.3.1 执行命令</a></div><div style='float:right;width:49%'>·<a href='100165601.htm'>21.3.2 调用存储过程</a></div></div>
</div>
</div>
</div>
<!-- main -->
<div id="main">
<div id="text">
<div id="csdn_zhaig_ad_yahoo_2"></div>
<link href="css.css" rel="stylesheet" type="text/css" /><h3 style="MARGIN-TOP: 8.15pt; MARGIN-LEFT: 0cm; MARGIN-RIGHT: 0cm; FTEL: 8.15pt"><a ftel="_Toc507815159"><span lang="EN-US">21.2.2 </span></a><span style="FONT-FAMILY: 黑体">事务处理</span></h3>
<p class="MsoNormal" style="LINE-HEIGHT: 15pt"><a ftel="transactions"><span style="FONT-FAMILY: 宋体">通常,对数据库要进行多次更新,这些更新必须在事务处理的范围内进行。</span><span lang="EN-US">ADO.NET</span></a><span style="FONT-FAMILY: 宋体">中的事务处理首先要在数据库连接对象上调用</span><span lang="EN-US">BeginTransaction()</span><span style="FONT-FAMILY: 宋体">方法,这些方法返回实现</span><span lang="EN-US">IDbTransaction</span><span style="FONT-FAMILY: 宋体">接口的对象,而该对象是在</span><span lang="EN-US">System.Data</span><span style="FONT-FAMILY: 宋体">中定义的。</span></p>
<p class="MsoNormal" style="LINE-HEIGHT: 15pt"><span style="FONT-FAMILY: 宋体">下面的代码序列是在</span><span lang="EN-US">Sql Server</span><span style="FONT-FAMILY: 宋体">连接上开始事务处理的:</span></p>
<p class="a6" style="MARGIN-TOP: 6.5pt; MARGIN-LEFT: 21.45pt; MARGIN-RIGHT: 0cm; FTEL: 18.45pt"><span lang="EN-GB">string source = "server=(local)\\NetSDK;" +</span></p>
<p class="a6" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB"> "</span><span lang="EN-GB"> </span><span lang="EN-GB">integrated security=SSPI;" + </span></p>
<p class="a6" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB"> "database=Northwind";</span></p>
<p class="a6" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB">SqlConnection conn = new SqlConnection(source);</span></p>
<p class="a6" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB">conn.Open();</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB">SqlTransaction tx = conn.BeginTransaction();</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB"> </span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB">// Execute some commands, then commit the transaction</span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB"> </span></p>
<p class="2" style="MARGIN-LEFT: 21.45pt; FTEL: 18.45pt"><span lang="EN-GB">tx.Commit();</span></p>
<p class="a6" style="MARGIN-TOP: 0cm; MARGIN-LEFT: 21.45pt; MARGIN-RIGHT: 0cm; FTEL: 18.45pt"><span lang="EN-GB">conn.Close();</span></p>
<p class="MsoNormal" style="LINE-HEIGHT: 15pt"><span style="FONT-FAMILY: 宋体; LETTER-SPACING: 0.1pt">在开始一个事务处理时,可以选择在该事务处理中执行的命令独立级别。该级别确定了如何在一个数据库会话中查看在另一个数据库会话中所进行的修改,并不是所有的数据库引擎都支持表</span><span lang="EN-US" style="LETTER-SPACING: 0.1pt">21-1</span><span style="FONT-FAMILY: 宋体; LETTER-SPACING: 0.1pt">所示的</span><span lang="EN-US" style="LETTER-SPACING: 0.1pt">4</span><span style="FONT-FAMILY: 宋体; LETTER-SPACING: 0.1pt">个级别。</span></p>
<p class="a5" style="MARGIN-TOP: 4.9pt"><a ftel="isolationlevels"><span style="FONT-FAMILY: 黑体">表</span></a><span lang="EN-GB"> 21-1</span></p>
<div align="center">
<table class="MsoNormalTable" style="MARGIN-LEFT: 0.35pt; WIDTH: 436pt; BORDER-TOP-STYLE: none; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none; BORDER-COLLAPSE: collapse; BORDER-BOTTOM-STYLE: none" cellspacing="0" cellpadding="0" width="581" border="1">
<tbody>
<tr>
<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 9.9pt; BORDER-TOP: windowtext 1pt solid; PADDING-LEFT: 9.9pt; BORDER-LEFT-WIDTH: 1pt; BORDER-LEFT-COLOR: windowtext; PADDING-BOTTOM: 1.4pt; WIDTH: 110.65pt; PADDING-TOP: 1.4pt; BORDER-BOTTOM: windowtext 1pt solid" valign="top" width="148">
<p class="a2" style="LINE-HEIGHT: 15.6pt"><span style="FONT-FAMILY: 黑体">独</span> <span style="FONT-FAMILY: 黑体">立</span> <span style="FONT-FAMILY: 黑体">级</span> <span style="FONT-FAMILY: 黑体">别</span></p>
</td>
<td style="PADDING-RIGHT: 9.9pt; BORDER-TOP: windowtext 1pt solid; PADDING-LEFT: 9.9pt; PADDING-BOTTOM: 1.4pt; WIDTH: 325.35pt; PADDING-TOP: 1.4pt; BORDER-BOTTOM: windowtext 1pt solid; BORDER-RIGHT-STYLE: none; BORDER-LEFT-STYLE: none" valign="top" width="434">
<p class="a2" style="LINE-HEIGHT: 15.6pt"><span style="FONT-FAMILY: 黑体">说</span><span lang="EN-US"> </span><span style="FONT-FAMILY: 黑体">明</span></p>
</td>
</tr>
<tr>
<td style="BORDER-RIGHT: windowtext 1pt solid; PADDING-RIGHT: 9.9pt; PADDING-LEFT: 9.9pt; PADDING-BOTTOM: 1.4pt; WIDTH: 110.65pt; BORDER-TOP-STYLE: none; PADDING-TOP: 1.4pt; BORDER-BOTTOM: windowtext 1pt solid; BORDER-LEFT-STYLE: none" valign="top" width="148">
<p class="a4" style="MARGIN-LEFT: 10.7pt; LINE-HEIGHT: 15.6pt"><span lang="EN-US">ReadCommitted</span></p>
</td>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -