C# 实现Table的Merge,Copy和Clone

本文介绍如何使用C#实现两个Table的数据合并,并演示了具体的代码实例。同时,还展示了如何复制表结构及数据,以及如何克隆表的结构和约束。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C#实现的对两个Table进行Merge,两表必须存在至c#教程少一个公共栏位作为连接项,否则连接就失去了意义。如下是对两个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
 
    }
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的详细内容

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值