[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
Web开发
> 详细
ADO.NET 事务控制
时间:
2018-06-23 16:45:17
阅读:
206
评论:
0
收藏:
0
[点我收藏+]
在ADO.NET 中,可以使用Connection 和Transaction 对象来控制事务。若要执行事务,请执行下列操作:
1.调用Connection 对象的BeginTransaction 方法来标记事务的开始。
2.将Transaction 对象分配给要执行的Command的Transaction 属性。
3.执行所需的命令。
4.调用Transaction 对象的Commit 方法来完成事务,或调用Rollback 方法来取消事务。 当然ADO.NET事务处理有优点和缺点,运用起来看具体情况了。
优点: – 简单性 – 和数据据事务差不多的快 – 独立于数据库,不同数据库的专有代码被隐藏了
缺点: – 事务不能跨越多个数据库连接 – 事务执行在数据库连接层上,所以需要在事务过程中维护一个数据库连接。
下边我们看一个例子,建立一个页面,同样简单,只需要一个按钮,然后编程:
1
using System;
2
using System.Data;
3
using System.Configuration;
4
using System.Collections;
5
using System.Web;
6
using System.Web.Security;
7
using System.Web.UI;
8
using System.Web.UI.WebControls;
9
using System.Web.UI.WebControls.WebParts;
10
using System.Web.UI.HtmlControls;
11
using System.Data.SqlClient;
12
13
namespace WebApplication1
14 {
15
public partial
class AdoAction : System.Web.UI.Page
16 {
17
protected
void Page_Load(
object sender, EventArgs e)
18 {
19
20 }
21
22
protected
void btn_Click(
object sender, EventArgs e)
23 {
24 SqlConnection con =
new SqlConnection();
25 con.ConnectionString = ConfigurationManager.ConnectionStrings[
" DSN " ].ConnectionString;
26 con.Open();
27
// 启动一个事务。
28 SqlTransaction myTran = con.BeginTransaction();
29
// 为事务创建一个命令,注意我们执行双条命令,第一次执行当然成功。我们再执行一次,失败。
30
// 第三次我们改其中一个命令,另一个不改,这时候事务会报错,这就是事务机制。
31 SqlCommand myCom =
new SqlCommand();
32 myCom.Connection = con;
33 myCom.Transaction = myTran;
34
try
35 {
36 myCom.CommandText =
" insert into SqlAction values (‘测试2‘,‘111‘) " ;
37 myCom.ExecuteNonQuery();
38 myCom.CommandText =
" insert into SqlAction values (‘测试3‘,‘111‘) " ;
39 myCom.ExecuteNonQuery();
40 myTran.Commit();
41 Response.Write(
" 成功执行 " );
42
43 }
44
catch (Exception Ex)
45 {
46 myTran.Rollback();
47
// 创建并且返回异常的错误信息
48 Response.Write(Ex.ToString());
49 Response.Write(
" 写入数据库失败 " );
50 }
51
finally
52 {
53 con.Close();
54 }
ADO.NET 事务控制
原文:https://www.cnblogs.com/qi123/p/9217325.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!