你必須知道的ADO.NET(九) 深入理解DataAdapter(下)

來源:互聯網
上載者:User

標籤:style   blog   class   code   java   tar   

摘要

    由於各種原因,很久沒有更新部落格了!期間,幾分迷茫,幾分失落。令人欣慰的是,園子裡還有很多熱心的讀者,都期待我更新部落格。想到自己的文章,能對園友有所協助,我又重拾久違的文筆,娓娓道來,樸實而不做作。在上一篇文章《你必須知道的ADO.NET(八) 深入理解DataAdapter(上)》中,我主要介紹了DataAdapter的工作原理以及準系統。在本文中,我將通過執行個體的方式講解如何使用DataAdapter對象。

目錄
  • 如何構造一個DataAdapter對象?
  • 填充資料到DataSet
  • 總結
 1. 如何構造一個DataAdapter對象?

    在講如何用DataAdapter擷取資料之前,先討論一個問題:如何構造一個DataApdater對象?我們知道DataAdapter是一個類,那麼如何建立一個類的對象呢(再次強調,本系列教程講的比較基礎,主要針對初學者)?呵呵,當然是用建構函式啦!因此,我們有必要瞭解一下DataAdapter的建構函式。通過前面的知識,我們已經很清晰的知道,對於不同的資料來源,ADO.NET提供了不同的Data Provider。以SQL Server資料庫為例,它擁有的DataAdapter為SqlDataAdapter類,它包括以下建構函式:

        public SqlDataAdapter();        public SqlDataAdapter(SqlCommand selectCommand);        public SqlDataAdapter(string selectCommandText, SqlConnection selectConnection);        public SqlDataAdapter(string selectCommandText, string selectConnectionString);

    對於建構函式的理解,我們主要看他包含哪些參數。從上面我們可以知道,SqlDataAdapter類包含4個顯式的建構函式。因此,我們必須用上述4個建構函式中的一種來執行個體化SqlDataAdapter類(建立SqlDataAdapter對象)。

提示:如果類中沒有聲明建構函式,建立對象時,將使用預設建構函式(無參數,無方法體)。 如果類中顯示聲明了建構函式(一個或者多個),那麼只能用聲明的建構函式來執行個體化類(系統將不會建立預設建構函式)。

 1.1 SqlDataAdapter()

     第一個建構函式相對來說比較簡單,它不包含參數。我們可以輕鬆的得到一個SqlDataAdapter對象:

 SqlDataAdapter ada = new SqlDataAdapter();

    OK,so easy!

 

 1.2 SqlDataAdapter(SqlCommand selectCommand)

    第二個建構函式稍微複雜點,它包含了一個SqlCommand類型的參數。我們可以這樣建立一個SqlDataAdatpter對象:

SqlCommand cmd = new SqlCommand();SqlDataAdapter ada = new SqlDataAdapter(cmd);

 

 1.3 SqlDataAdapter(string selectCommandText, SqlConnection selectConnection)

  第三個建構函式,它包含了2個參數。第一個參數是字串類型,它接受一個查詢指令。第2個參數是SqlConnection類型,它表示一個連線物件。OK,我們還是寫個例子吧!

string selCmdStr = "select * from tb_SelCustomer";SqlConnection conn = new SqlConnection();SqlDataAdapter ada = new SqlDataAdapter(selCmdStr, conn);

 

 1.4 SqlDataAdapter(string selectCommandText, string selectConnectionString)

   最後一個建構函式,它也包含了2個參數。2個參數均為字串類型:第一個參數,它接受一個查詢指令;第二個參數,它表示一個連接字串。同樣,我們也寫個例子。

string selCmdStr = "select * from tb_SelCustomer";string connStr = @"Data Source=.\SQLEXPRESS; Initial Catalog=db_MyDemo; Integrated Security=SSPI";//構造連接字串SqlDataAdapter ada = new SqlDataAdapter(selCmdStr, connStr);

 

2. 填充資料到DataSet

  上面我詳細了的介紹了如何構造一個DataAdapter對象。之所以很詳細,因為只有構造好一個DataAdapter對象,我們才能發揮出它的功能。其中,它一個非常重要的功能就是填充資料到DataSet。SqlDataAdapter類除了有4個建構函式之外,還包含多個Fill()方法(方法重載)。一般來說,用的比較多的是int Fill(DataTable dt),  int Fill(DataSet ds),這2個方法分別接受 DataTable 參數和 DataSet 參數。擁有Fill()方法,我們可以輕鬆地將外部資料源中的資料填充到DataSet中。廢話不多說,還是寫個執行個體來加深理解。

 1 using System; 2 using System.Collections.Generic; 3 using System.Linq; 4 using System.Text; 5 using System.Data; 6 using System.Data.SqlClient; 7  8 namespace DataAdapter2 9 {10     class Program11     {12         static void Main(string[] args)13         {14             string connStr = @"Data Source=.\SQLEXPRESS; Initial Catalog=db_MyDemo; Integrated Security=SSPI";//連接字串15             string selCmdStr = "select * from tb_SelCustomer";//查詢指令16 17             using (SqlConnection conn = new SqlConnection(connStr))18             {19                 SqlDataAdapter ada = new SqlDataAdapter(selCmdStr, conn);20 21                 DataSet ds = new DataSet();22                 ada.Fill(ds);23 24                 if (ds.Tables.Count > 0)25                 {26                     PrintDataTable(ds.Tables[0]);27                 }28             }29 30             Console.Read();31         }32 33         /// <summary>34         /// 列印出DataTable中的內容35         /// </summary>36         static void PrintDataTable(DataTable dt)37         {38             int col = dt.Columns.Count;39 40             foreach (DataRow row in dt.Rows)41             {42                 for (int i = 0; i < col; ++i)43                 {44                     Console.Write("{0}\t", row[i]);45                 }46             }47         }48     }49 50 }

輸出結果:

 

3. 總結

   在本節中,我們主要學習了Adatapter對象的建構函式以及如何填充資料到DataSet。Adatapter建構函式比較多,特點鮮明。在實際開發中,你可以選擇一種合適的建構函式來建立DataAdapter對象。就我個人經驗來說,第2個和第3個建構函式用的比較多。如果查詢指令不帶參數,則使用第3個建構函式;如果查詢指令帶參數,則使用第2個建構函式。

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

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.