C# 實(shí)現(xiàn)Table的Merge,Copy和Clone
C#實(shí)現(xiàn)的對(duì)兩個(gè)Table進(jìn)行Merge,兩表必須存在至少一個(gè)公共欄位作為連接項(xiàng),否則連接就失去了意義。如下是對(duì)兩個(gè)table進(jìn)行Merge的詳細(xì)代碼:
private void button1_Click(object sender, EventArgs e)//Button點(diǎn)擊觸發(fā)事件 { #region Table的Merge DataTable dt = new DataTable(); DataTable dt1 = new DataTable();//創(chuàng)建Table1 dt1.Columns.Add("ID", typeof(string)); dt1.Columns.Add("NAME",typeof(string)); dt1.Columns.Add("AGE", typeof(int)); dt1.Columns.Add("SEX", typeof(string)); dt1.PrimaryKey = new DataColumn[] { dt1.Columns["ID"]}; for (int i = 0; i < 5; i++) { DataRow dr = dt1.NewRow(); dr["ID"] = "00" + i.ToString(); dr["NAME"] = "00-" + i.ToString(); dr["AGE"] = 15 + i; dr["SEX"] = "M"; dt1.Rows.Add(dr); } dt = dt1; DataTable dt2 = new DataTable();//創(chuàng)建Table2 dt2.Columns.Add("ID", typeof(string)); dt2.Columns.Add("NAME", typeof(string)); dt2.Columns.Add("Course",typeof(string)); dt2.Columns.Add("Score",typeof(int)); dt2.PrimaryKey = new DataColumn[] { dt2.Columns["ID"] }; for (int i = 0; i < 5; i++) { DataRow dr = dt2.NewRow(); dr["ID"] = "00" + i.ToString(); dr["NAME"] = "00-" + i.ToString(); dr["Course"] ="C#"; dr["Score"] = i + 80; dt2.Rows.Add(dr); } dt = dt2; dt1.Merge(dt2); //Copy var table1 = dt1.Copy();//Copy,復(fù)制表的結(jié)構(gòu)以及數(shù)據(jù) //添加新的一行 DataRow dr1 = table1.NewRow(); dr1["ID"] = "005"; dr1["NAME"] = "00-5"; dr1["AGE"] = 15; dr1["SEX"] = "F"; table1.Rows.InsertAt(dr1,2);//表的指定位置插入新增加的一行 table1.Columns.Add(new DataColumn() { ColumnName = "Memo", DataType = typeof(string) });//默認(rèn)插入到最後一列 table1.Columns["Memo"].SetOrdinal(0);//把插入的列移動(dòng)到第一行 int memoIndex = table1.Columns.IndexOf("Memo");//獲取列的位置信息 var isContainName = table1.Columns.Contains("NAME");//判斷table中是否存在某列 List<string> columnsNameList = new List<string>();//遍歷獲取table的所有列名 foreach (DataColumn col in table1.Columns) { columnsNameList.Add(col.ColumnName); } table1.Columns.RemoveAt(memoIndex);//通過(guò)列名的索引進(jìn)行移除 table1.Columns.RemoveAt(2);//通過(guò)列名的索引進(jìn)行移除 table1.Columns.Remove("SEX");//通過(guò)列名進(jìn)行移除,建議使后者 string[] name = new string[table1.Rows.Count];//方法一:對(duì)表中的數(shù)據(jù)進(jìn)行遍歷輸出 string[] id = new string[table1.Rows.Count]; for (int i = 0; i < table1.Rows.Count; i++) { name[i] = table1.Rows[i]["NAME"].ToString(); id[i] = table1.Rows[i]["ID"].ToString(); } table1.Clear();//清空表中的數(shù)據(jù) //Clone var table2 = dt2.Clone();//Clone,復(fù)制表的結(jié)構(gòu)、約束信息 #endregion }
以上就是C# 實(shí)現(xiàn)Table的Merge,Copy和Clone的詳細(xì)內(nèi)容,更多關(guān)于c# table Merge的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- C# 實(shí)現(xiàn)TXT文檔轉(zhuǎn)Table的示例代碼
- C# DataTable與Model互轉(zhuǎn)的示例代碼
- C# DataTable常見(jiàn)用法匯總
- C# ArrayList、HashSet、HashTable、List、Dictionary的區(qū)別詳解
- C#讀取Excel到DataTable的方法示例
- C#實(shí)現(xiàn)Json轉(zhuǎn)DataTable并導(dǎo)出Excel的方法示例
- C#使用Datatable導(dǎo)出Excel
- C#中DataTable 轉(zhuǎn)實(shí)體實(shí)例詳解
- 詳解C#把DataTable中數(shù)據(jù)一次插入數(shù)據(jù)庫(kù)的方法
相關(guān)文章
C#表達(dá)式樹(shù)Expression基礎(chǔ)講解
這篇文章介紹了C#表達(dá)式樹(shù)Expression和基本用法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-12-12C#身份證識(shí)別相關(guān)技術(shù)功能詳解
這篇文章主要介紹了C#身份證識(shí)別相關(guān)技術(shù)詳解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07C#使用Socket快速判斷數(shù)據(jù)庫(kù)連接是否正常的方法
這篇文章主要介紹了C#使用Socket快速判斷數(shù)據(jù)庫(kù)連接是否正常的方法,涉及C#中socket操作的相關(guān)技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-04-04c#和avascript加解密之間的互轉(zhuǎn)代碼分享
這篇文章主要介紹了c#和Javascript間互轉(zhuǎn)的Xxtea加解密代碼,需要的朋友可以參考下2014-02-02