Asp.net 在三层架构中事务的使用实例代码
2012-10-08 00:00
1001 查看
接触3层也有一段时间了,了解水平一般,前段时间在想在三层中怎么使用事务呢,放在哪呢?Sqlherper ? DAL? BLL?。然后我就疯狂的百度,好几次都是未果(因为做的都是小项目,不用事务也关系不大),今天我再次查时,好好的看了csdn上的以讨论,http://topic.csdn.net/u/20091101/19/f21697d7-8f0c-4eb3-8e59-d0fe2f0b04b0.html,结合前辈和高手们的意见,自己改了一个出来。我的想法是将事务逻辑写在业务逻辑层,数据库的处理还都是在SQLHELPER,BLL层通过事务SqlTransaction传值访问DAL,再访问Sqlhelper。接下来是分块的代码。
Sqlhelper:
DAL:
BLL:
上述代码在此次测试中通过,若要用于真实项目中,请修改后再使用,还有本人水平一般,写的不到之处请大家见谅。欢迎大家指导指正。
Sqlhelper:
private static SqlConnection Cnn = new SqlConnection(DbConfig.ConnectionString); #region 判读SqlConnection 是否开启连接 并开启 /// <summary> /// 判读SqlConnection 是否开启连接 并开启 /// </summary> /// <returns>返回SqlConnection</returns> private static SqlConnection GetCnn() { if (Cnn.State == ConnectionState.Closed) { Cnn.Open(); } return Cnn; } #endregion #region 关闭数据库连接 /// <summary> /// 关闭数据库连接 /// </summary> public static void CloseCnn() { Cnn.Close(); } #endregion #region 产生一个事务并开始 /// <summary> /// 产生一个事务并开始 /// </summary> /// <returns>返回此事务</returns> public static SqlTransaction BeginTransaction() { SqlTransaction tran = GetCnn().BeginTransaction(); return tran; } #endregion
DAL:
public bool test(int i,SqlTransaction tran) { string sql = "insert into [test]([item]) values(@i)"; SqlParameter[] paras=new SqlParameter[]{new SqlParameter("@i",i)}; return sqlhelper.ExecutenQuery(sql, paras, CommandType.Text, tran)>0; }
BLL:
UserDAO userdao = new UserDAO(); public bool test() { using (SqlTransaction tran = SQLHelper.BeginTransaction()) { try { userdao.test(2, tran); userdao.test(3, tran); tran.Commit(); return true; } catch { tran.Rollback(); return false; } finally { SQLHelper.CloseCnn();//关闭数据库连接 } } }
上述代码在此次测试中通过,若要用于真实项目中,请修改后再使用,还有本人水平一般,写的不到之处请大家见谅。欢迎大家指导指正。
相关文章推荐
- asp.net 事务的处理,dts 的设置,asp.net三种事务处理方法,三层架构,微软企业库,动软生成器生成的代码下如何使用事务
- Asp.net 在三层架构中事务的使用
- 三层架构中使用实体类填充泛型集合代替DataTable解决方案(ASP.NET+C#)
- 三层架构中使用实体类填充泛型集合代替DataTable解决方案(ASP.NET+C#)
- ASP.NET 4.0 与 Entity Framework 4-第四篇-Entity Framework在三层架构中的使用
- 三层架构中使用实体类填充泛型集合代替DataTable解决方案(ASP.NET+C#)
- 三层架构中使用实体类填充泛型集合代替DataTable解决方案(ASP.NET+C#)
- 三层架构中使用实体类填充泛型集合代替DataTable解决方案(ASP.NET+C#)
- 三层架构中使用实体类填充泛型集合代替DataTable解决方案(ASP.NET+C#)
- [转]微软代码示例:ASP.NET 2.0 三层架构应用程序教程系列
- 三层架构中使用实体类填充泛型集合代替DataTable解决方案(ASP.NET+C#)
- 使用ASP.NET中关于代码分离的实例分享
- 三层架构中使用实体类填充泛型集合代替DataTable解决方案(ASP.NET+C#)
- 使用ASP.NET中关于代码分离的实例分享
- asp.net session的使用与过期实例代码
- asp.net一个带抽象工厂的三层架构完整实例
- asp.net session的使用与过期实例代码
- asp.net mvc应用架构的思考--Unity的应用及三层代码
- asp.net mvc应用架构的思考--Unity的应用及三层代码