这篇文章主要介绍了C# 实现Table的Merge,Copy和Clone,帮助大家更好的利用c#处理文件,感兴趣的朋友可以了解下
C#实现的对两个Table进行Merge,两表必须存在至少一个公共栏位作为连接项,否则连接就失去了意义。如下是对两个table进行Merge的详细代码:
private void button1_Click(object sender, EventArgs e)//Button点击触发事件
{
#region Table的Merge
DataTable dt = new DataTable();
DataTable dt1 = new DataTable();//创建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();//创建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,复制表的结构以及数据
//添加新的一行
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) });//默認插入到最後一列
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);//通过列名的索引进行移除
table1.Columns.RemoveAt(2);//通过列名的索引进行移除
table1.Columns.Remove("SEX");//通过列名进行移除,建议使后者
string[] name = new string[table1.Rows.Count];//方法一:对表中的数据进行遍历输出
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();//清空表中的数据
//Clone
var table2 = dt2.Clone();//Clone,复制表的结构、约束信息
#endregion
}
以上就是C# 实现Table的Merge,Copy和Clone的详细内容,更多关于c# table Merge的资料请关注得得之家其它相关文章!
沃梦达教程
本文标题为:C# 实现Table的Merge,Copy和Clone
基础教程推荐
猜你喜欢
- character-encoding – Linux中最常见的C语言编码(和Unix?) 2023-11-21
- C语言数组长度的计算方法实例总结(sizeof与strlen) 2023-04-26
- Qt数据库应用之实现通用数据库请求 2023-03-18
- C语言的三种条件判断语句你都了解吗 2023-03-05
- C语言植物大战数据结构二叉树递归 2023-04-09
- 纯C++代码详解二叉树相关操作 2023-05-15
- 05-C语言进阶——动态内存管理 2023-11-20
- g++: const 丢弃限定符 2022-10-07
- VisualStudio2010安装教程 2023-01-05
- 利用QT设计秒表功能 2023-05-30
