欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#使用SqlDataAdapter對象獲取數(shù)據(jù)的方法

 更新時間:2016年02月23日 09:04:34   作者:禮拜一  
這篇文章主要介紹了C#使用SqlDataAdapter對象獲取數(shù)據(jù)的方法,結合實例形式較為詳細的分析了SqlDataAdapter對象獲取數(shù)據(jù)具體步驟與相關使用技巧,需要的朋友可以參考下

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

一.SqlDataAdapter對象

1. SqlDataAdapter特性

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

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

2. SqlDataAdapter的設置

SqlCommand屬性

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

TabbleMappings集合

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

SqlDataAdapter的TableMappings屬性返回一個DataTableMappingsConnention對象,它包含DataTableMapping對象的集合。每個對象允許在數(shù)據(jù)庫中的一個表(或視圖或存儲過程)與DataSet中相對應的DataTable的名稱之間建立一種映射;TableMappings對象具有ColumnMappings屬性,它返回DataColumnMappings對象組成的集合,每個DataColumnMappings對象對應數(shù)據(jù)庫查詢結果中的一列映射到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 關鍵字

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

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

SqlDataAdapter的構造函數(shù)

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

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

2. 獲取查詢中的結果

使用Fill方法

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

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

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

使用重載的Fill方法

指定DataTable

da.Fill(DataSet,"MyTableName")
// SqlDataAdapter填充指定DataSet的特定表。

da.Fill(DataTable);
// SqlDataAdapter填充已經(jīng)創(chuàng)建的DataTable對象。

Fill方法分頁顯示

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

調(diào)用SqlDataAdapter對象Fill方法過程的數(shù)據(jù)庫連接的打開與關閉

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

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

DataSet中數(shù)據(jù)的更新

如果DataSet中的數(shù)據(jù)需要更新,在調(diào)用Fill方法之前應該先清除DataSet或DataTable中的數(shù)據(jù),這樣可以確保DataTable中不會出現(xiàn)重復的數(shù)據(jù)行,也不會出現(xiàn)數(shù)據(jù)庫中已經(jīng)不存在的數(shù)據(jù)行。

3. 將查詢結果映射到DataSet

TableMappings映射

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

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

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

TableMappings和ColumnMappings的AddRange方法

構造并賦值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屬性

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

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

Ignore  忽略映射中沒有出現(xiàn)的列;

Error 在出現(xiàn)不匹配的情況下引發(fā)異常;

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

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

相關文章

  • c# Struct的一些問題分析

    c# Struct的一些問題分析

    在 C# 中,結構體是值類型數(shù)據(jù)結構。它使得一個單一變量可以存儲各種數(shù)據(jù)類型的相關數(shù)據(jù)。struct 關鍵字用于創(chuàng)建結構體。結構體是用來代表一個記錄。
    2021-06-06
  • C#中Task.ContinueWith連續(xù)任務使用實例

    C#中Task.ContinueWith連續(xù)任務使用實例

    本文主要介紹了C#中Task.ContinueWith連續(xù)任務使用實例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • c#基于NVelocity實現(xiàn)代碼生成

    c#基于NVelocity實現(xiàn)代碼生成

    這篇文章主要介紹了c#基于NVelocity實現(xiàn)代碼生成的方法,幫助大家更好的理解和使用c#,感興趣的朋友可以了解下
    2021-01-01
  • C#使用分部類設計實現(xiàn)一個計算器

    C#使用分部類設計實現(xiàn)一個計算器

    分部類是C#4.5中的一個新特性,它的出現(xiàn)使得程序的結構更加合理,代碼組織更加緊密,本文將使用分部類設計實現(xiàn)一個簡單的計算器,感興趣的小伙伴可以了解下
    2024-02-02
  • C# 對文件與文件夾的操作包括刪除、移動與復制

    C# 對文件與文件夾的操作包括刪除、移動與復制

    在.Net中,對文件(File)和文件夾(Folder)的操作可以使用File類和Directory類,也可以使用FileInfo類和DirectoryInfo類,本文將詳細介紹,需要的朋友可以參考
    2012-11-11
  • 詳解C#如何實現(xiàn)窗體換膚

    詳解C#如何實現(xiàn)窗體換膚

    這篇文章主要為大家詳細介紹了如何利用C#實現(xiàn)窗體換膚,文中的示例代碼講解詳細,對我們學習C#有一定的幫助,感興趣的小伙伴可以跟隨小編一起了解一下
    2022-12-12
  • C#使用虛擬方法實現(xiàn)多態(tài)

    C#使用虛擬方法實現(xiàn)多態(tài)

    這篇文章主要介紹了C#使用虛擬方法實現(xiàn)多態(tài),涉及C#多態(tài)的實現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-05-05
  • C#動態(tài)創(chuàng)建Access數(shù)據(jù)庫及密碼的方法

    C#動態(tài)創(chuàng)建Access數(shù)據(jù)庫及密碼的方法

    同為微軟的產(chǎn)品,本文將討論的是C#如何創(chuàng)建Access數(shù)據(jù)庫,同時創(chuàng)建數(shù)據(jù)庫密碼與相關操作,希望對大家有所幫助。
    2015-09-09
  • 在WinForm應用程序中快速實現(xiàn)多語言的處理的方法

    在WinForm應用程序中快速實現(xiàn)多語言的處理的方法

    在國際化環(huán)境下,越來越多的程序需要做多語言版本,這篇文章主要介紹了在WinForm應用程序中快速實現(xiàn)多語言的處理的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下。
    2018-07-07
  • 使用遞歸實現(xiàn)數(shù)組求和示例分享

    使用遞歸實現(xiàn)數(shù)組求和示例分享

    這篇文章主要介紹了使用遞歸實現(xiàn)數(shù)組求和示例,思路是給定一個含有n個元素的整型數(shù)組a,求a中所有元素的和,需要的朋友可以參考下
    2014-03-03

最新評論