C# 实现Table的Merge,Copy和Clone

作者:農碼一生 时间:2021-07-03 02:24:58 

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

}

来源:https://www.cnblogs.com/wml-it/p/12204838.html

标签:c#,table,Merge,copy,clone
0
投稿

猜你喜欢

  • spring boot 静态资源处理方法

    2022-07-14 22:12:42
  • C#利用控件拖拽技术制作拼图游戏

    2023-05-24 21:27:34
  • 如何使用C#在PDF文件添加图片印章

    2021-06-26 05:34:51
  • Android编程实现手机自带内部存储路径的获取方法

    2022-05-14 11:59:11
  • Java并发编程同步器CountDownLatch

    2022-10-17 18:59:34
  • 解析Kotlin JSON格式

    2021-07-16 08:09:35
  • Java环境下高德地图Api的使用方式

    2022-06-13 06:43:59
  • SpringBoot整合Mybatis与druid实现流程详解

    2022-09-17 17:05:31
  • Java中重载与重写的对比与区别

    2021-08-29 13:22:31
  • Android开发手册TextView属性实现效果盘点

    2022-03-10 09:29:53
  • java多线程编程学习(线程间通信)

    2023-04-02 05:25:34
  • Java语言读取配置文件config.properties的方法讲解

    2023-09-29 14:45:51
  • Android使用VideoView播放本地视频和网络视频的方法

    2023-06-28 11:17:32
  • Java实现inputstream流的复制代码实例

    2021-08-30 11:52:11
  • C#端口扫描器的编写方法

    2023-12-17 17:47:24
  • Java毕业设计实战之图片展览馆管理系统的实现

    2021-06-16 08:23:18
  • c# 用ICSharpCode组件压缩文件

    2021-06-23 16:52:10
  • C# 抽象类,抽象属性,抽象方法(实例讲解)

    2022-03-14 09:22:16
  • java中Vector类的常用方法详解

    2023-11-26 10:29:07
  • Java使用组合模式实现表示公司组织结构功能示例

    2022-07-31 08:03:37
  • asp之家 软件编程 m.aspxhome.com