標籤: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個建構函式。