成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

打造自己的數(shù)據(jù)訪問層一

數(shù)據(jù)庫
項(xiàng)目開發(fā)中,大多數(shù)開發(fā)人員的核心工作就是如何對數(shù)據(jù)進(jìn)行存儲及訪問。.NET中,ADO.NET可以使用DbConnection進(jìn)行連接,DataSet進(jìn)行數(shù)據(jù)存儲,DataAdapter進(jìn)行數(shù)據(jù)更新。

項(xiàng)目開發(fā)中,大多數(shù)開發(fā)人員的核心工作就是如何對數(shù)據(jù)進(jìn)行存儲及訪問。為了進(jìn)行數(shù)據(jù)操作,我們首先得解決幾個(gè)基本問題:

1、如何與一個(gè)數(shù)據(jù)庫建立連接。

2、如何從數(shù)據(jù)庫讀取相應(yīng)的數(shù)據(jù)。

3、如何對數(shù)據(jù)表進(jìn)行增改操作。

.NET中,ADO.NET很方便的解決了上面三個(gè)問題,我們可以使用DbConnection進(jìn)行連接,DataSet進(jìn)行數(shù)據(jù)存儲,DataAdapter進(jìn)行數(shù)據(jù)更新。先看一段代碼:

  1. //創(chuàng)建DbConnection對象連接數(shù)據(jù)庫
  2. SqlConnection conn = new SqlConnection();
  3. conn.ConnectionString = "server=.;uid=sa;password=123456; database=DATA_BASE; max pool size=300;";
  4. //創(chuàng)建DataAdapter、Command對象,讀取數(shù)據(jù)
  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. //創(chuàng)建DataSet對象,存儲數(shù)據(jù),建立與物理表的映射
  11. DataSet ds = new DataSet();
  12. da.Fill(ds, "TEST"); 

上述代碼實(shí)現(xiàn)對數(shù)據(jù)庫“DATA_BASE”中“TEST”表數(shù)據(jù)讀取,并用DataSet時(shí)行存儲。

既然讀出了TEST表中的數(shù)據(jù),接下來要解決的就是如何對TEST表進(jìn)行增、刪、改操作。

為實(shí)現(xiàn)增、刪、改操作,需要為DataAdapter指定InsertCommand、DeleteCommand以及UpdateCommand,并為每個(gè)Command對象綁定參數(shù):

  1. //新增數(shù)據(jù)  
  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. //修改數(shù)據(jù)  
  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. //刪除數(shù)據(jù)  
  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;  

完成準(zhǔn)備工作后,利用DataTable進(jìn)行數(shù)據(jù)操作:

  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();  

***調(diào)用DataAdapter的Update方法保存變更后的數(shù)據(jù):

da.Update(ds, "TEST");

利用ADO.NET的上述方法,我們已經(jīng)完成了對數(shù)據(jù)庫的完整操作。

注:上述代碼是利用DataAdapter對數(shù)據(jù)庫進(jìn)行讀寫的基本原理,非常重要,我們后面的改造都將以此作為依據(jù)。

雖然我們已經(jīng)能完成對數(shù)據(jù)的操作,但現(xiàn)實(shí)際上還是存在很多問題:

1、我們只是對MSSql數(shù)據(jù)庫進(jìn)行操作,如果要對Oracle或MySql進(jìn)行操作我們得定義新的Oracle或MySql數(shù)據(jù)對象,如果能由系統(tǒng)自動判斷操作的數(shù)據(jù)庫類型,我們就能省去對數(shù)據(jù)對象的關(guān)注。

2、我們做了太多的準(zhǔn)備工作,我們只對一張表進(jìn)行操作,如查我們要對多張表進(jìn)行操作,參數(shù)又很多,實(shí)際上會產(chǎn)生大量的重復(fù)代碼,我們得考慮消除這些代碼。

對于上述問題,如果我們自己實(shí)現(xiàn)一個(gè)數(shù)據(jù)訪問層,對ADO.NET對象進(jìn)行封裝,只關(guān)注實(shí)際的數(shù)據(jù)的操作,而不關(guān)注系統(tǒng)是如何與數(shù)據(jù)庫進(jìn)行連接、如何進(jìn)行參數(shù)傳遞,那我們的需求就算基本滿足了。

我們可以先進(jìn)行假設(shè),需要達(dá)成如下效果,以偽碼的形式給出:

  1. 創(chuàng)建數(shù)據(jù)執(zhí)行者:DataExecuter:execObj;    
  2. 創(chuàng)建數(shù)據(jù)映射對象:DataMapping map;    
  3. 由映射對象填充數(shù)據(jù)集:map.Fill(sqlText, "TEST", ds);    
  4. 設(shè)置映射對象更新命令:map.SetCommands(Insert | Update | Delete, ds);    
  5. DataTable進(jìn)行實(shí)際增、刪、改操作。    
  6. 數(shù)據(jù)執(zhí)行者執(zhí)行***的變更操作:execObj.Update(ds);    

 

后面我將一步步看到上述假設(shè)是如何實(shí)現(xiàn)的。

原文鏈接:http://www.cnblogs.com/FlySoul/archive/2011/05/02/2034368.html

【編輯推薦】

  1. 曬曬我的通用數(shù)據(jù)訪問層
  2. 幾步走,教你創(chuàng)建簡單訪問數(shù)據(jù)庫方法
  3. 一句代碼實(shí)現(xiàn)批量數(shù)據(jù)綁定 下
  4. 一步一步設(shè)計(jì)你的數(shù)據(jù)庫1
  5. 不重復(fù)隨機(jī)數(shù)列生成算法

 

責(zé)任編輯:艾婧 來源: 博客園
相關(guān)推薦

2011-05-10 16:44:43

數(shù)據(jù)訪問層

2011-05-05 14:33:34

數(shù)據(jù)訪問層

2009-01-08 09:52:26

2011-03-29 09:15:28

通用數(shù)據(jù)訪問層

2012-01-11 09:46:31

DAL

2009-08-13 14:59:00

C#數(shù)據(jù)訪問層

2016-02-15 14:13:39

Python編碼環(huán)境

2010-03-17 16:06:15

Linux 常用應(yīng)用軟

2013-11-26 09:47:47

ORM

2009-08-04 10:17:55

ASP.NET SqlASP.NET數(shù)據(jù)訪問

2009-08-19 10:54:42

ASP.NET數(shù)據(jù)訪問

2009-09-04 18:00:54

C#數(shù)據(jù)訪問層

2012-06-07 10:53:08

架構(gòu)設(shè)計(jì)數(shù)據(jù)訪問層設(shè)計(jì)原則

2020-12-14 08:09:03

弱口令工具掃描

2015-10-15 09:37:50

桌面環(huán)境發(fā)行版Linux

2014-03-27 15:24:43

農(nóng)行大數(shù)據(jù)

2021-06-06 19:03:25

SQL大數(shù)據(jù)Spark

2009-07-24 13:25:43

創(chuàng)建數(shù)據(jù)訪問層

2012-08-15 11:03:18

框架項(xiàng)目

2015-09-01 09:49:28

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 日本在线播放一区二区 | 一级一片在线观看 | 午夜国产一级 | 国产乱码精品一区二区三区中文 | 中文字幕免费视频 | 一本一道久久a久久精品蜜桃 | 干干干操操操 | 久久久久久久久久一区二区 | 国产精品一区二区欧美黑人喷潮水 | 亚洲在线一区二区 | 在线免费黄色小视频 | 国产一区二 | 国产激情在线播放 | 91精品国产色综合久久不卡98 | 免费看91 | 日日夜夜草 | 欧美成人精品在线观看 | 91久久精品 | 国产一区二区精品在线观看 | 波霸ol一区二区 | 亚洲97| 成人在线视频一区 | 狠狠操狠狠 | 夜夜骑首页 | 国产成人免费在线 | 精品在线看 | 91精品国产91久久久久久密臀 | 罗宾被扒开腿做同人网站 | 国产成人精品一区二区三区在线 | 久久精品91久久久久久再现 | 国产精品久久久久aaaa九色 | 亚洲成人www | 成人看片在线观看 | 亚洲精品久久久一区二区三区 | 国产视频福利一区 | 亚洲精品一级 | 亚洲二区在线观看 | 日韩美女一区二区三区在线观看 | 国产一区二区三区久久久久久久久 | 毛片免费在线 | 在线播放中文字幕 |