博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Asp.net 在三层架构中事务的使用
阅读量:5345 次
发布时间:2019-06-15

本文共 2515 字,大约阅读时间需要 8 分钟。

         再我知道的.net中,执行事务有两种方法,一种是自动事物,使用起来相当简单,但是需要配置服务器,如果你用的是web共享主机,即没有权限配置自己的服务器,那就没必要用这种了,接下了我讲下.net中最普通的事务SqlTransaction。

         接触3层也有一段时间了,了解水平一般,前段时间在想在三层中怎么使用事务呢,放在哪呢?Sqlherper ?    DAL?   BLL?。然后我就疯狂的百度,好几次都是未果(因为做的都是小项目,不用事务也关系不大),今天我再次查时,好好的看了csdn上的以讨论,,结合前辈和高手们的意见,自己改了一个出来。我的想法是将事务逻辑写在业务逻辑层,数据库的处理还都是在SQLHELPER,BLL层通过事务SqlTransaction传值访问DAL,再访问Sqlhelper。接下来是分块的代码。

 

Sqlhelper:

1 private static SqlConnection Cnn = new SqlConnection(DbConfig.ConnectionString);  2  3         #region 判读SqlConnection 是否开启连接 并开启  4         ///   5 /// 判读SqlConnection 是否开启连接 并开启  6 ///   7 /// 
返回SqlConnection
8 private static SqlConnection GetCnn() 9 {
10 if (Cnn.State == ConnectionState.Closed) 11 {
12 Cnn.Open(); 13 } 14 return Cnn; 15 } 16 #endregion 17 18 #region 关闭数据库连接 19 /// 20 /// 关闭数据库连接 21 /// 22 public static void CloseCnn() 23 {
24 Cnn.Close(); 25 } 26 #endregion 27 28 #region 产生一个事务并开始 29 /// 30 /// 产生一个事务并开始 31 /// 32 ///
返回此事务
33 public static SqlTransaction BeginTransaction() 34 {
35 SqlTransaction tran = GetCnn().BeginTransaction(); 36 return tran; 37 } 38 #endregion

 

DAL:

1 public bool test(int i,SqlTransaction tran) 2         {
3 string sql = "insert into [test]([item]) values(@i)"; 4 SqlParameter[] paras=new SqlParameter[]{
new SqlParameter("@i",i)}; 5 return sqlhelper.ExecutenQuery(sql, paras, CommandType.Text, tran)>0; 6 }

BLL:

1 UserDAO userdao = new UserDAO();  2  3  4         public bool test()  5         {  6             using (SqlTransaction tran = SQLHelper.BeginTransaction())  7             {  8                 try  9                 { 10                     userdao.test(2, tran); 11                     userdao.test(3, tran); 12                     tran.Commit(); return true; 13                 } 14                 catch 15                 {
16 17 tran.Rollback(); 18 return false; 19 } 20 finally 21 {
22 SQLHelper.CloseCnn();//关闭数据库连接 23 } 24 } 25 }

上述代码在此次测试中通过,若要用于真实项目中,请修改后再使用,还有本人水平一般,写的不到之处请大家见谅。欢迎大家指导指正。

转载于:https://www.cnblogs.com/yyl8781697/archive/2012/02/01/SqlTransaction.html

你可能感兴趣的文章
linux下部署一个JavaEE项目的简单步骤
查看>>
hash储存机制
查看>>
[Android学习系列16]Android把php输出的json加载到listview
查看>>
20145205 《信息安全系统设计基础》第14周学习总结
查看>>
6)添加一个窗口的图标
查看>>
POJ - 1422 Air Raid 二分图最大匹配
查看>>
Road Map
查看>>
正则替换中的一个Bug
查看>>
HI3531uboot开机画面 分类: arm-linux-Ubunt...
查看>>
制作U盘启动CDLinux 分类: 生活百科 ...
查看>>
strcpy函数里的小九九
查看>>
搭建ssm过程中遇到的问题集
查看>>
OpenLayers绘制图形
查看>>
tp5集合h5 wap和公众号支付
查看>>
Flutter学习笔记(一)
查看>>
iOS10 国行iPhone联网权限问题处理
查看>>
洛谷 P1991 无线通讯网
查看>>
[HIHO1184]连通性二·边的双连通分量(双连通分量)
查看>>
Codeforces Round #178 (Div. 2) B. Shaass and Bookshelf 【动态规划】0-1背包
查看>>
SparkStreaming 源码分析
查看>>