C#使用SqlDataAdapter對(duì)象獲取數(shù)據(jù)的方法
本文實(shí)例講述了C#使用SqlDataAdapter對(duì)象獲取數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
一.SqlDataAdapter對(duì)象
1. SqlDataAdapter特性
SqlDataAdapter類用作ADO.NET對(duì)象模型中和數(shù)據(jù)連接部分和未連接部分之間的橋梁。SqlDataAdapter從數(shù)據(jù)庫(kù)中獲取數(shù)據(jù),并將其存儲(chǔ)在DataSet中。SqlDataAdapter也可能取得DataSet中的更新,并將它們提交給數(shù)據(jù)庫(kù)。
SqlDataAdapter是為處理脫機(jī)數(shù)據(jù)而設(shè)計(jì)的,調(diào)用其Fill方法填充DataSet時(shí)甚至不需要與數(shù)據(jù)庫(kù)的活動(dòng)連接。即如果調(diào)用Fill方法時(shí),SqlDataAdapter與數(shù)據(jù)庫(kù)的連接不是打開(kāi)時(shí),SqlDataAdapter將打開(kāi)數(shù)據(jù)庫(kù)連接,查詢數(shù)據(jù)庫(kù),提取查詢結(jié)果,將查詢結(jié)果填入DataSet,然后關(guān)閉也數(shù)據(jù)庫(kù)的連接。
2. SqlDataAdapter的設(shè)置
SqlCommand屬性
SqlDataAdapter將查詢結(jié)果存儲(chǔ)到DataSet中時(shí),SqlDataAdapter使用SqlCommand和SqlConnection與數(shù)據(jù)庫(kù)進(jìn)行通信。SqlDataAdapter在內(nèi)部使用SqlDataReader獲取結(jié)果,并將信息存儲(chǔ)到DataSet的新行。SqlCommand類的屬性包括SelectCommand、InsertCommand、UpdateCommand、DeleteCommand分別對(duì)應(yīng)數(shù)據(jù)庫(kù)的查詢、插入、更新和刪除操作。
TabbleMappings集合
默認(rèn)情況下,SqlDataAdapter假定SqlDataReader中的列與DataSet中的列匹配,但實(shí)際情況中往往期望DataSet的架構(gòu)不同于數(shù)據(jù)庫(kù)的架構(gòu),因此SqlDataAdapter提供了一種將查詢結(jié)果映射到DataSet結(jié)果的機(jī)制:TableMappings集合。
SqlDataAdapter的TableMappings屬性返回一個(gè)DataTableMappingsConnention對(duì)象,它包含DataTableMapping對(duì)象的集合。每個(gè)對(duì)象允許在數(shù)據(jù)庫(kù)中的一個(gè)表(或視圖或存儲(chǔ)過(guò)程)與DataSet中相對(duì)應(yīng)的DataTable的名稱之間建立一種映射;TableMappings對(duì)象具有ColumnMappings屬性,它返回DataColumnMappings對(duì)象組成的集合,每個(gè)DataColumnMappings對(duì)象對(duì)應(yīng)數(shù)據(jù)庫(kù)查詢結(jié)果中的一列映射到DataSet中DataTable中的一列。示例代碼如下:
Using System.Data.Common; SqlDataAdapter da=new SqlDataAdapter(); //初始化DataAdapter DataTableMapping tableMap; tableMap=da.TableMappings.Add("Table","Employees"); tableMap.ColumnMappings.Add("EmpID","EmployeeID"); tableMap.ColumnMappings.Add("LName","LastName");
二.SqlDataAdapter的創(chuàng)建與使用
1. 創(chuàng)建SqlDataAdapter
New 關(guān)鍵字
New 關(guān)鍵字建立新的SqlDataAdapter對(duì)象后,再設(shè)置其SqlCommand屬性
SqlDataAdapter da=new SqlDataAdapter(); da.SelectCommand=cmd;
SqlDataAdapter的構(gòu)造函數(shù)
strSql是查詢數(shù)符串;strConn是數(shù)據(jù)庫(kù)連接字符串;cmd是SqlCommand對(duì)象;cn是SqlConnection對(duì)象。
SqlDataAdapter da=new SqlDataAdapter(strSql,strConn); SqlDataAdapter da=new SqlDataAdapter(strSql,cn); SqlDataAdapter da=new SqlDataAdapter(cmd);
2. 獲取查詢中的結(jié)果
使用Fill方法
調(diào)用SqlDataAdapter類的Fill方法會(huì)執(zhí)行存儲(chǔ)在SqlDataAdapter對(duì)象的SqlCommand屬性中的查詢,并將查詢結(jié)果存儲(chǔ)在DataSet中。示例代碼如下:
SqlDataAdapter da=new SqlDataAdapter(strSql,strConn); DataSet ds =new DataSet(); da.Fill(ds);
執(zhí)行以上代碼后,DataSet的實(shí)例對(duì)象ds中會(huì)創(chuàng)建一個(gè)新的DataTable,這個(gè)DataTable擁有strSql查詢語(yǔ)句中所包括的字段,但DataTable對(duì)象的名稱為默認(rèn)的Table,而不是查詢語(yǔ)句中所查詢的表的名稱。
使用重載的Fill方法
指定DataTable
da.Fill(DataSet,"MyTableName") // SqlDataAdapter填充指定DataSet的特定表。
da.Fill(DataTable); // SqlDataAdapter填充已經(jīng)創(chuàng)建的DataTable對(duì)象。
Fill方法分頁(yè)顯示
da.Fill(DataSet,intStartRecord,intNumRecord,"TableName"); //Fill方法可能很輕松的實(shí)現(xiàn)分頁(yè)顯示,但操作效率很低。
調(diào)用SqlDataAdapter對(duì)象Fill方法過(guò)程的數(shù)據(jù)庫(kù)連接的打開(kāi)與關(guān)閉
SqlDataAdapter的Fill方法調(diào)用前不需要有活動(dòng)的SqlConnection對(duì)象,SqlDataAdapter會(huì)自己打開(kāi)strConn語(yǔ)句中的數(shù)據(jù)庫(kù),獲取查詢結(jié)果后,關(guān)閉與數(shù)據(jù)庫(kù)的連接。如果已經(jīng)存在SqlConnection對(duì)象,無(wú)論是否已經(jīng)打開(kāi),SqlDataAdapter執(zhí)行完Fill方法后,均會(huì)將SqlConnection對(duì)象返回到原始狀態(tài)。
當(dāng)程序中的多個(gè)SqlDataAdapter對(duì)象使用都一個(gè)SqlConnection對(duì)象時(shí),為避免多次打開(kāi)與關(guān)閉SqlConnection對(duì)象,應(yīng)該在調(diào)用SqlDataAdapter的Fill方法前調(diào)用SqlConnection的Open方法打開(kāi)數(shù)據(jù)庫(kù)的連接,待完成Fill調(diào)用后再調(diào)用SqlConnection的Close方法關(guān)閉數(shù)據(jù)庫(kù)的連接。
DataSet中數(shù)據(jù)的更新
如果DataSet中的數(shù)據(jù)需要更新,在調(diào)用Fill方法之前應(yīng)該先清除DataSet或DataTable中的數(shù)據(jù),這樣可以確保DataTable中不會(huì)出現(xiàn)重復(fù)的數(shù)據(jù)行,也不會(huì)出現(xiàn)數(shù)據(jù)庫(kù)中已經(jīng)不存在的數(shù)據(jù)行。
3. 將查詢結(jié)果映射到DataSet
TableMappings映射
TabbleMappings集合控制SqlDataAdapter如何將DataSet映射到數(shù)據(jù)庫(kù)。如果保持TabbleMappings集合為空,調(diào)用Fill方法,然后將DataSet作為參數(shù),而不指定表名,SqlDataAdapter將假定您希望使用一個(gè)名為"Table"的DataTable來(lái)裝載數(shù)據(jù)。
SqlDataAdapter.TableMappings.Add("Table","Employees")
此語(yǔ)句的作用是將DataSet中原來(lái)名字為"Table"的DataTable命名為"Employees",DataSet填充數(shù)據(jù)時(shí),按查詢結(jié)果集的順序依次填充DataSet中的Table、Table1、Table2……,所以給DataTable命名時(shí)需留意該DataTable是否為當(dāng)前將要使用的對(duì)象。
TableMappings和ColumnMappings的AddRange方法
構(gòu)造并賦值DataTableMapping、DataColumnMapping數(shù)組,再調(diào)用它們的AddRange方法將該集合整體添加到映射數(shù)組。
DataTableMapping tableMap; tableMap=da.TableMapping.Add("Table","Employees"); DataColumnMapping[] columnMaps; columnMaps=new DataColumnMapping[]; {new DataColumnMapping ("EmpID","EmployeeID"), new DataColumnMapping ("LName","LastName") } tableMap.ColumnMapping.AddRange(columnMaps);
MissingMappingAction屬性
當(dāng)SqlDataAdapter提取查詢結(jié)果來(lái)填充DataSet時(shí),它將檢查TableMappings集合,如果存在結(jié)果集中列不在TableMappings集合時(shí),它將查看MissingMappingAction屬性的值來(lái)決定如何操作。
Passthrough 映射中沒(méi)有出現(xiàn)的列仍然填充到DataSet,采用原結(jié)果集的名稱;
Ignore 忽略映射中沒(méi)有出現(xiàn)的列;
Error 在出現(xiàn)不匹配的情況下引發(fā)異常;
更多關(guān)于C#相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《C#面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《WinForm控件用法總結(jié)》及《C#常見(jiàn)控件用法教程》
希望本文所述對(duì)大家C#程序設(shè)計(jì)有所幫助。
上一篇:在winform下實(shí)現(xiàn)左右布局多窗口界面的方法之續(xù)篇
欄 目:C#教程
本文標(biāo)題:C#使用SqlDataAdapter對(duì)象獲取數(shù)據(jù)的方法
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/6656.html
您可能感興趣的文章
- 01-10C#使用Dispose模式實(shí)現(xiàn)手動(dòng)對(duì)資源的釋放
- 01-10C#3.0使用EventLog類寫(xiě)Windows事件日志的方法
- 01-10C#使用windows服務(wù)開(kāi)啟應(yīng)用程序的方法
- 01-10c# ArrayList的使用方法小總結(jié)
- 01-10C#使用ADO.Net部件來(lái)訪問(wèn)Access數(shù)據(jù)庫(kù)的方法
- 01-10C#使用Mutex簡(jiǎn)單實(shí)現(xiàn)程序單實(shí)例運(yùn)行的方法
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10C#實(shí)現(xiàn)獲取不同對(duì)象中名稱相同屬性的方法
- 01-10C#編程自學(xué)之類和對(duì)象
- 01-10C#中yield用法使用說(shuō)明


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開(kāi)的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過(guò)重寫(xiě)Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 04-02jquery與jsp,用jquery
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10C#中split用法實(shí)例總結(jié)
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 01-10delphi制作wav文件的方法