Asp.net 在三层架构中事务的使用
再我知道的.net中,执行事务有两种方法,一种是自动事物,使用起来相当简单,但是需要配置服务器,如果你用的是web共享主机,即没有权限配置自己的服务器,那就没必要用这种了,接下了我讲下.net中最普通的事务SqlTransaction。
接触3层也有一段时间了,了解水平一般,前段时间在想在三层中怎么使用事务呢,放在哪呢?Sqlherper ? DAL? BLL?。然后我就疯狂的百度,好几次都是未果(因为做的都是小项目,不用事务也关系不大),结合前辈和高手们的意见,自己改了一个出来。我的想法是将事务逻辑写在业务逻辑层,数据库的处理还都是在SQLHELPER,BLL层通过事务SqlTransaction传值访问DAL,再访问Sqlhelper。接下来是分块的代码。
Sqlhelper:
1 private static SqlConnection Cnn = new SqlConnection(DbConfig.ConnectionString);
2
3 #region 判读SqlConnection 是否开启连接 并开启
4 /// <summary>
5 /// 判读SqlConnection 是否开启连接 并开启
6 /// </summary>
7 /// <returns>返回SqlConnection</returns>
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 /// <summary>
20 /// 关闭数据库连接
21 /// </summary>
22 public static void CloseCnn()
23 {
24 Cnn.Close();
25 }
26 #endregion
27
28 #region 产生一个事务并开始
29 /// <summary>
30 /// 产生一个事务并开始
31 /// </summary>
32 /// <returns>返回此事务</returns>
33 public static SqlTransaction BeginTransaction()
34 {
35 SqlTransaction tran = GetCnn().BeginTransaction();
相关新闻>>
- 发表评论
-
- 最新评论 更多>>