打造自己的資料訪問層一

來源:互聯網
上載者:User

項目開發中,大多數開發人員的核心工作就是如何對資料進行儲存及訪問。為了進行資料操作,我們首先得解決幾個基本問題:

1、如何與一個資料庫建立串連。

2、如何從資料庫讀取相應的資料。

3、如何對資料表進行增改操作。

.NET中,ADO.NET很方便的解決了上面三個問題,我們可以使用DbConnection進行串連,DataSet進行資料存放區,DataAdapter進行資料更新。先看一段代碼:

 
  1. //建立DbConnection對象串連資料庫
  2. SqlConnection conn = new SqlConnection();
  3. conn.ConnectionString = "server=.;uid=sa;password=123456; database=DATA_BASE; max pool size=300;";
  4. //建立DataAdapter、Command對象,讀取資料
  5. SqlDataAdapter da = new SqlDataAdapter();
  6. SqlCommand cmd = new SqlCommand();
  7. cmd.Connection = conn;
  8. cmd.CommandText = "SELECT * FROM TEST";
  9. da.SelectCommand = cmd;
  10. //建立DataSet對象,儲存資料,建立與物理表的映射
  11. DataSet ds = new DataSet();
  12. da.Fill(ds, "TEST"); 

上述代碼實現對資料庫“DATA_BASE”中“TEST”表資料讀取,並用DataSet時行儲存。

既然讀出了TEST表中的資料,接下來要解決的就是如何對TEST表進行增、刪、改操作。

為實現增、刪、改操作,需要為DataAdapter指定InsertCommand、DeleteCommand以及UpdateCommand,並為每個Command對象綁定參數:

 
  1. //新增資料  
  2. cmd = new SqlCommand();  
  3. cmd.Connection = conn;  
  4. cmd.CommandText = "INSERT INTO TEST (ID, NAME, VAL) VALUES (@ID, @NAME, @VAL)";  
  5. SqlParameter param = new SqlParameter("@ID", null);  
  6. param.SourceColumn = "ID";  
  7. cmd.Parameters.Add(param);  
  8. param = new SqlParameter("@NAME", null);  
  9. param.SourceColumn = "NAME";  
  10. cmd.Parameters.Add(param);  
  11. param = new SqlParameter("@VAL", null);  
  12. param.SourceColumn = "VAL";  
  13. cmd.Parameters.Add(param);  
  14. da.InsertCommand = cmd;  
  15.  
  16. //修改資料  
  17. cmd = new SqlCommand();  
  18. cmd.Connection = conn;  
  19. cmd.CommandText = "UPDATE TEST SET NAME = @NAME, VAL = @VAL WHERE ID = @ID";  
  20. param = new SqlParameter("@ID", null);  
  21. param.SourceColumn = "ID";  
  22. cmd.Parameters.Add(param);  
  23. param = new SqlParameter("@NAME", null);  
  24. param.SourceColumn = "NAME";  
  25. cmd.Parameters.Add(param);  
  26. param = new SqlParameter("@VAL", null);  
  27. param.SourceColumn = "VAL";  
  28. cmd.Parameters.Add(param);  
  29. da.UpdateCommand = cmd;  
  30.  
  31. //刪除資料  
  32. cmd = new SqlCommand();  
  33. cmd.Connection = conn;cmd.CommandText = "DELETE FROM TEST WHERE ID = @ID";  
  34. param = new SqlParameter("@ID", null);  
  35. param.SourceColumn = "ID";  
  36. cmd.Parameters.Add(param);  
  37. da.DeleteCommand = cmd;  

完成準備工作後,利用DataTable進行資料操作:

 
  1. DataTable dt = ds.Tables["TEST"];  
  2. dt.PrimaryKey = new DataColumn[] { dt.Columns["ID"] };  
  3. dt.Rows.Add(new object[]{  
  4.     Guid.NewGuid().ToString(), string.Format("測試:{0}", DateTime.Now), string.Format("測試值:{0}", DateTime.Now)  
  5. });  
  6. DataRow dr = dt.Rows.Find("f8dc2c64-f51a-4e99-bde1-a20069b09c3a");  
  7. if (dr != null){  
  8.     dr["NAME"] = string.Format("測試修改:{0}", DateTime.Now);  
  9. }  
  10. dr = dt.Rows.Find("ed7d079b-81ec-4ba4-bf85-688621e495e7");  
  11. if (dr != null){      
  12. dr.Delete();  

最後調用DataAdapter的Update方法儲存變更後的資料:

da.Update(ds, "TEST");

利用ADO.NET的上述方法,我們已經完成了對資料庫的完整操作。

註:上述代碼是利用DataAdapter對資料庫進行讀寫的基本原理,非常重要,我們後面的改造都將以此作為依據。

雖然我們已經能完成對資料的操作,但現實際上還是存在很多問題:

1、我們只是對MSSql資料庫進行操作,如果要對Oracle或MySql進行操作我們得定義新的Oracle或MySql資料對象,如果能由系統自動判斷操作的資料庫類型,我們就能省去對資料對象的關注。

2、我們做了太多的準備工作,我們只對一張表進行操作,如查我們要對多張表進行操作,參數又很多,實際上會產生大量的重複代碼,我們得考慮消除這些代碼。

對於上述問題,如果我們自己實現一個資料訪問層,對ADO.NET對象進行封裝,只關注實際的資料的操作,而不關注系統是如何與資料庫進行串連、如何進行參數傳遞,那我們的需求就算基本滿足了。

我們可以先進行假設,需要達成如下效果,以偽碼的形式給出:

 
  1. 建立資料執行者:DataExecuter:execObj;    
  2. 建立資料對應對象:DataMapping map;    
  3. 由映射對象填充資料集:map.Fill(sqlText, "TEST", ds);    
  4. 設定映射對象更新命令:map.SetCommands(Insert | Update | Delete, ds);    
  5. DataTable進行實際增、刪、改操作。    
  6. 資料執行者執行最後的變更操作:execObj.Update(ds);    

後面我將一步步看到上述假設是如何?的。

相關文章

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.