Asp.net 在三層架構中事務的使用



         再我知道的.net中,執行事務有兩種方法,一種是自動事物,使用起來相當簡單,但是需要配置服務器,如果你用的是web共享主機,即沒有權限配置自己的服務器,那就沒必要用這種了,接下了我講下.net中最普通的事務SqlTransaction。

         接觸3層也有一段時間了,了解水平一般,前段時間在想在三層中怎么使用事務呢,放在哪呢?Sqlherper ?    DAL?   BLL?。然后我就瘋狂的百度,好幾次都是未果(因為做的都是小項目,不用事務也關系不大),今天我再次查時,好好的看了csdn上的以討論,http://topic.csdn.net/u/20091101/19/f21697d7-8f0c-4eb3-8e59-d0fe2f0b04b0.html,結合前輩和高手們的意見,自己改了一個出來。我的想法是將事務邏輯寫在業務邏輯層,數據庫的處理還都是在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();
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 }




上述代碼在此次測試中通過,若要用於真實項目中,請修改后再使用,還有本人水平一般,寫的不到之處請大家見諒。歡迎大家指導指正。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM