C# 實現(xiàn)Table的Merge,Copy和Clone
C#實現(xiàn)的對兩個Table進(jìn)行Merge,兩表必須存在至少一個公共欄位作為連接項,否則連接就失去了意義。如下是對兩個table進(jìn)行Merge的詳細(xì)代碼:
private void button1_Click(object sender, EventArgs e)//Button點擊觸發(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);//把插入的列移動到第一行
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);//通過列名的索引進(jìn)行移除
table1.Columns.RemoveAt(2);//通過列名的索引進(jìn)行移除
table1.Columns.Remove("SEX");//通過列名進(jìn)行移除,建議使后者
string[] name = new string[table1.Rows.Count];//方法一:對表中的數(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# 實現(xiàn)Table的Merge,Copy和Clone的詳細(xì)內(nèi)容,更多關(guān)于c# table Merge的資料請關(guān)注腳本之家其它相關(guān)文章!
- C# 實現(xiàn)TXT文檔轉(zhuǎn)Table的示例代碼
- C# DataTable與Model互轉(zhuǎn)的示例代碼
- C# DataTable常見用法匯總
- C# ArrayList、HashSet、HashTable、List、Dictionary的區(qū)別詳解
- C#讀取Excel到DataTable的方法示例
- C#實現(xiàn)Json轉(zhuǎn)DataTable并導(dǎo)出Excel的方法示例
- C#使用Datatable導(dǎo)出Excel
- C#中DataTable 轉(zhuǎn)實體實例詳解
- 詳解C#把DataTable中數(shù)據(jù)一次插入數(shù)據(jù)庫的方法
相關(guān)文章
Visual C#.Net 網(wǎng)絡(luò)程序開發(fā)-Socket篇
Visual C#.Net 網(wǎng)絡(luò)程序開發(fā)-Socket篇...2007-03-03
C# 使用 Castle 實現(xiàn) AOP及如何用 Autofac 集成 Castle
這篇文章主要介紹了C# 使用 Castle 實現(xiàn) AOP及如何用 Autofac 集成 Castle,幫助大家更好的理解和學(xué)習(xí)使用c#,感興趣的朋友可以了解下2021-02-02
C#實現(xiàn)Quartz任務(wù)調(diào)度的示例代碼
使用 Quartz.NET,你可以很容易地安排任務(wù)在應(yīng)用程序啟動時運(yùn)行,或者每天、每周、每月的特定時間運(yùn)行,甚至可以基于更復(fù)雜的調(diào)度規(guī)則,本文給大家介紹了C#實現(xiàn)Quartz任務(wù)調(diào)度,需要的朋友可以參考下2024-04-04
C#程序員應(yīng)該養(yǎng)成的程序性能優(yōu)化寫法
工作和生活中經(jīng)??梢钥吹揭恍┏绦蛟?寫代碼的時候只關(guān)注代碼的邏輯性,而不考慮運(yùn)行效率,其實這對大多數(shù)程序猿來說都是沒有問題的,不過作為一只有理想的CodeMonkey,我還是希望給大家分享一些性能優(yōu)化心得2017-08-08
winfrom 在業(yè)務(wù)層實現(xiàn)事務(wù)控制的小例子
winfrom 在業(yè)務(wù)層實現(xiàn)事務(wù)控制的小例子,需要的朋友可以參考一下2013-03-03

