關(guān)于ADO.NET對象DataTable基本用法講解
ADO.NET對象還是比較常用的,于是我研究了一下ADO.NET對象,在這里拿出來和大家分享一下,希望對大家有用。ADO.NET可以在與數(shù)據(jù)庫斷開連接的方式下通過DataSet或DataTable對象進(jìn)行數(shù)據(jù)處理,當(dāng)需要更新數(shù)據(jù)時(shí)才重新與數(shù)據(jù)源進(jìn)行連接,并更新數(shù)據(jù)源。DataTable對象表示保存在本機(jī)內(nèi)存中的表,它提供了對表中行列數(shù)據(jù)對象的各種操作。
#T#可以直接將數(shù)據(jù)從數(shù)據(jù)庫填充到DataTable對象中,也可以將DataTable對象添加到現(xiàn)有的DataSet對象中。在斷開連接的方式下,DataSet對象提供了和關(guān)系數(shù)據(jù)庫一樣的關(guān)系數(shù)據(jù)模型,代碼中可以直接訪問DataSet對象中的DataTable對象,也可以添加、刪除ADO.NET對象DataTable。ADO.NET對象SqlDataAdapter通過SelectCommand、InsertCommand、UpdateCommand和 DeleteCommand屬性為后臺數(shù)據(jù)庫提供對應(yīng)的操作命令,并傳遞需要的參數(shù)。一般情況下,只需要提供SELECT語句和連接字符串創(chuàng)建 SqlDataAdapter對象,然后利用SqlCommandBuilder對象生成InsertCommand、UpdateCommand和 DeleteCommand屬性。
1.創(chuàng)建DataTable對象
可以通過以下兩種方式創(chuàng)建DataTable對象:
1) 通過DataTable類的構(gòu)造函數(shù)創(chuàng)建DataTable對象,例如:
- DataTable table = new DataTable();
2) 通過DataSet的Tables對象的Add方法創(chuàng)建DataTable對象,例如:
- DataSet dataset = new DataSet();
- DataTable table = dataset.Tables.Add("MyTableName");
2. 在DataTable對象中添加列
在DataTable對象中添加列的最常用的方法是通過DataTable對象的Column屬性中的Add方法。添加后的每一列都是一個(gè)DataColumn對象。
3. 設(shè)置DataTable對象的主鍵
關(guān)系數(shù)據(jù)庫中的表一般都有一個(gè)主鍵,用來惟一標(biāo)識表中的每一行記錄。通過DataTable對象的PrimaryKey屬性可以設(shè)置Datatable的主鍵。主鍵可以是一個(gè)或者多個(gè)DataColumn對象組成的數(shù)組。例如:
- DataColumn[] key = new DataColumn[1];//dt是一個(gè)DataTable對象
- key[0] = dt.Columns[0];
- dt.PrimaryKey = key;
4. 在DataTable對象中創(chuàng)建行
DataTable對象的每一行都是一個(gè)DataRow對象,所以創(chuàng)建行時(shí)可以先利用DataTable對象的NewRow方法創(chuàng)建一個(gè)DataRow對象,并設(shè)置新行中各列的數(shù)據(jù),然后利用Add方法將DataRow對象添加到表中
5. 將SQL Server數(shù)據(jù)庫中的表填充到DataTable中
除了可以直接創(chuàng)建ADO.NET對象DataTable的行列信息外,也可以通過DateAdapter對象的Fill方法將SQL Server數(shù)據(jù)庫中的表填充到DataTable對象中。

















