亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#使用SqlDataAdapter對象獲取數據的方法

2020-01-24 01:15:48
字體:
來源:轉載
供稿:網友

本文實例講述了C#使用SqlDataAdapter對象獲取數據的方法。分享給大家供大家參考,具體如下:

一.SqlDataAdapter對象

1. SqlDataAdapter特性

SqlDataAdapter類用作ADO.NET對象模型中和數據連接部分和未連接部分之間的橋梁。SqlDataAdapter從數據庫中獲取數據,并將其存儲在DataSet中。SqlDataAdapter也可能取得DataSet中的更新,并將它們提交給數據庫。

SqlDataAdapter是為處理脫機數據而設計的,調用其Fill方法填充DataSet時甚至不需要與數據庫的活動連接。即如果調用Fill方法時,SqlDataAdapter與數據庫的連接不是打開時,SqlDataAdapter將打開數據庫連接,查詢數據庫,提取查詢結果,將查詢結果填入DataSet,然后關閉也數據庫的連接。

2. SqlDataAdapter的設置

SqlCommand屬性

SqlDataAdapter將查詢結果存儲到DataSet中時,SqlDataAdapter使用SqlCommand和SqlConnection與數據庫進行通信。SqlDataAdapter在內部使用SqlDataReader獲取結果,并將信息存儲到DataSet的新行。SqlCommand類的屬性包括SelectCommand、InsertCommand、UpdateCommand、DeleteCommand分別對應數據庫的查詢、插入、更新和刪除操作。

TabbleMappings集合

默認情況下,SqlDataAdapter假定SqlDataReader中的列與DataSet中的列匹配,但實際情況中往往期望DataSet的架構不同于數據庫的架構,因此SqlDataAdapter提供了一種將查詢結果映射到DataSet結果的機制:TableMappings集合。

SqlDataAdapter的TableMappings屬性返回一個DataTableMappingsConnention對象,它包含DataTableMapping對象的集合。每個對象允許在數據庫中的一個表(或視圖或存儲過程)與DataSet中相對應的DataTable的名稱之間建立一種映射;TableMappings對象具有ColumnMappings屬性,它返回DataColumnMappings對象組成的集合,每個DataColumnMappings對象對應數據庫查詢結果中的一列映射到DataSet中DataTable中的一列。示例代碼如下:

Using System.Data.Common;SqlDataAdapter da=new SqlDataAdapter();//初始化DataAdapterDataTableMapping tableMap;tableMap=da.TableMappings.Add("Table","Employees");tableMap.ColumnMappings.Add("EmpID","EmployeeID");tableMap.ColumnMappings.Add("LName","LastName");

二.SqlDataAdapter的創建與使用

1. 創建SqlDataAdapter

New 關鍵字

New 關鍵字建立新的SqlDataAdapter對象后,再設置其SqlCommand屬性

SqlDataAdapter da=new SqlDataAdapter();da.SelectCommand=cmd;

SqlDataAdapter的構造函數

strSql是查詢數符串;strConn是數據庫連接字符串;cmd是SqlCommand對象;cn是SqlConnection對象。

SqlDataAdapter da=new SqlDataAdapter(strSql,strConn);SqlDataAdapter da=new SqlDataAdapter(strSql,cn);SqlDataAdapter da=new SqlDataAdapter(cmd);

2. 獲取查詢中的結果

使用Fill方法

調用SqlDataAdapter類的Fill方法會執行存儲在SqlDataAdapter對象的SqlCommand屬性中的查詢,并將查詢結果存儲在DataSet中。示例代碼如下:

SqlDataAdapter da=new SqlDataAdapter(strSql,strConn);DataSet ds =new DataSet();da.Fill(ds);

執行以上代碼后,DataSet的實例對象ds中會創建一個新的DataTable,這個DataTable擁有strSql查詢語句中所包括的字段,但DataTable對象的名稱為默認的Table,而不是查詢語句中所查詢的表的名稱。

使用重載的Fill方法

指定DataTable

da.Fill(DataSet,"MyTableName")// SqlDataAdapter填充指定DataSet的特定表。
da.Fill(DataTable);// SqlDataAdapter填充已經創建的DataTable對象。

Fill方法分頁顯示

da.Fill(DataSet,intStartRecord,intNumRecord,"TableName");//Fill方法可能很輕松的實現分頁顯示,但操作效率很低。

調用SqlDataAdapter對象Fill方法過程的數據庫連接的打開與關閉

SqlDataAdapter的Fill方法調用前不需要有活動的SqlConnection對象,SqlDataAdapter會自己打開strConn語句中的數據庫,獲取查詢結果后,關閉與數據庫的連接。如果已經存在SqlConnection對象,無論是否已經打開,SqlDataAdapter執行完Fill方法后,均會將SqlConnection對象返回到原始狀態。

當程序中的多個SqlDataAdapter對象使用都一個SqlConnection對象時,為避免多次打開與關閉SqlConnection對象,應該在調用SqlDataAdapter的Fill方法前調用SqlConnection的Open方法打開數據庫的連接,待完成Fill調用后再調用SqlConnection的Close方法關閉數據庫的連接。

DataSet中數據的更新

如果DataSet中的數據需要更新,在調用Fill方法之前應該先清除DataSet或DataTable中的數據,這樣可以確保DataTable中不會出現重復的數據行,也不會出現數據庫中已經不存在的數據行。

3. 將查詢結果映射到DataSet

TableMappings映射

TabbleMappings集合控制SqlDataAdapter如何將DataSet映射到數據庫。如果保持TabbleMappings集合為空,調用Fill方法,然后將DataSet作為參數,而不指定表名,SqlDataAdapter將假定您希望使用一個名為"Table"的DataTable來裝載數據。

SqlDataAdapter.TableMappings.Add("Table","Employees")

此語句的作用是將DataSet中原來名字為"Table"的DataTable命名為"Employees",DataSet填充數據時,按查詢結果集的順序依次填充DataSet中的Table、Table1、Table2……,所以給DataTable命名時需留意該DataTable是否為當前將要使用的對象。

TableMappings和ColumnMappings的AddRange方法

構造并賦值DataTableMapping、DataColumnMapping數組,再調用它們的AddRange方法將該集合整體添加到映射數組。

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屬性

當SqlDataAdapter提取查詢結果來填充DataSet時,它將檢查TableMappings集合,如果存在結果集中列不在TableMappings集合時,它將查看MissingMappingAction屬性的值來決定如何操作。

Passthrough 映射中沒有出現的列仍然填充到DataSet,采用原結果集的名稱;

Ignore  忽略映射中沒有出現的列;

Error 在出現不匹配的情況下引發異常;

更多關于C#相關內容感興趣的讀者可查看本站專題:《C#面向對象程序設計入門教程》、《WinForm控件用法總結》及《C#常見控件用法教程

希望本文所述對大家C#程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
正在播放国产一区| 成人av.网址在线网站| 91九色视频导航| 国产成人亚洲综合91精品| 欧美猛少妇色xxxxx| zzijzzij亚洲日本成熟少妇| 欧美成年人视频| 日韩视频第一页| 91精品国产自产91精品| 国产精品精品视频一区二区三区| 亚洲乱码一区二区| 亚洲视频欧洲视频| 午夜精品久久久久久久99热浪潮| 久久久亚洲天堂| 欧美成人合集magnet| 国产精品欧美风情| 色99之美女主播在线视频| 国产成人亚洲综合91| 91精品国产乱码久久久久久久久| 亚洲自拍偷拍第一页| 亚洲sss综合天堂久久| 久久精品国产亚洲| 精品在线欧美视频| 亚洲国产精品va在线| 精品国产91久久久| 国产精品丝袜久久久久久高清| 国产91在线播放九色快色| 97超碰蝌蚪网人人做人人爽| 狠狠综合久久av一区二区小说| 久久综合伊人77777尤物| 欧美在线亚洲一区| 日韩中文字幕网| 日韩在线一区二区三区免费视频| 日韩激情第一页| 成人信息集中地欧美| 亚洲影院污污.| 97人人爽人人喊人人模波多| 清纯唯美日韩制服另类| 亚洲精品按摩视频| 欧美黑人一级爽快片淫片高清| 日韩av影视在线| 亚洲欧美中文日韩在线v日本| 国产免费观看久久黄| 97免费视频在线播放| 18性欧美xxxⅹ性满足| 日韩欧美在线视频| 国产有码在线一区二区视频| 亚洲黄一区二区| 国产www精品| 国产97人人超碰caoprom| 国内精品久久久久影院优| 久久久天堂国产精品女人| 中文字幕亚洲欧美在线| 日韩网站在线观看| 狠狠色香婷婷久久亚洲精品| 国产成人综合亚洲| 久久久噜噜噜久噜久久| 欧美日韩国产专区| 亚洲人成电影在线观看天堂色| 精品久久久久国产| 国产精品a久久久久久| 精品国产1区2区| 欧美黑人狂野猛交老妇| 狠狠色香婷婷久久亚洲精品| 亚洲欧美在线免费| 92版电视剧仙鹤神针在线观看| 久久久久在线观看| 国产91网红主播在线观看| 国产精品久久久久aaaa九色| 欧美激情精品久久久久久蜜臀| 亚洲在线观看视频网站| 精品国偷自产在线视频| 亚洲综合自拍一区| 欧美黑人性生活视频| 成人日韩av在线| www.日本久久久久com.| 欧美乱妇40p| 亚洲一区二区自拍| 久久视频在线免费观看| 亚洲欧洲在线播放| 欧美老女人性视频| 91精品免费久久久久久久久| 色多多国产成人永久免费网站| 日韩av手机在线看| 亚洲黄色av网站| 欧美一级视频免费在线观看| 日韩中文在线中文网在线观看| 91人人爽人人爽人人精88v| 日韩精品在线免费观看| 9.1国产丝袜在线观看| 国产aⅴ夜夜欢一区二区三区| 欧美日本高清视频| 国产精品日日摸夜夜添夜夜av| 欧美另类暴力丝袜| 亚洲最大在线视频| 日本精品久久中文字幕佐佐木| 久久精品国产成人精品| 国产一区私人高清影院| 久久久久久国产精品| 亚洲综合自拍一区| 亚洲国产日韩一区| 亚洲天堂av在线免费观看| 国产日韩欧美中文| 米奇精品一区二区三区在线观看| 日韩一级裸体免费视频| 亚洲美女在线视频| 91成人福利在线| 国内精品免费午夜毛片| 欧美在线视频免费| 国产精品久久久久久久av电影| 亚洲免费精彩视频| 97超级碰在线看视频免费在线看| 日韩中文字幕久久| 国产欧美一区二区三区四区| 国产精品成人va在线观看| 国产精品久久久久99| 97国产一区二区精品久久呦| 色七七影院综合| 久久久久久网址| 亚洲一区美女视频在线观看免费| 亚洲国产91精品在线观看| 欧美极品美女视频网站在线观看免费| 国产一区二区丝袜| 91精品国产高清久久久久久| 欧美视频在线观看 亚洲欧| 欧美在线日韩在线| 精品女同一区二区三区在线播放| 国产一区二区三区网站| 亚洲片国产一区一级在线观看| 国产精品视频最多的网站| 欧美在线观看网站| 欧美激情免费看| 久久成人综合视频| 久久国产精品久久久久久久久久| 欧美高清一级大片| 中文字幕亚洲综合久久| 91香蕉电影院| 欧美一级免费视频| 欧美激情va永久在线播放| 成人性生交大片免费看视频直播| 欧美国产中文字幕| 亚洲精品中文字幕女同| 亚洲国产精品国自产拍av秋霞| 亚洲黄页视频免费观看| 亚洲国产第一页| 亚洲精品永久免费精品| 亚洲欧美日韩图片| 精品视频偷偷看在线观看| 国产一区二区丝袜| 亚洲色图在线观看| 色偷偷888欧美精品久久久| 夜夜嗨av色一区二区不卡| 亚洲精品自在久久| 亚洲欧洲自拍偷拍| 欧美成人黑人xx视频免费观看| 97超碰蝌蚪网人人做人人爽| 91成人在线观看国产| 最近更新的2019中文字幕| 国内伊人久久久久久网站视频| 日韩精品久久久久久福利| 亚洲第一区在线| 欧美一级大片视频| 亚洲电影免费在线观看| 日韩美女写真福利在线观看|