软件编程
位置:首页>> 软件编程>> C#编程>> C# 实现Table的Merge,Copy和Clone

C# 实现Table的Merge,Copy和Clone

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

标签:c#,table,Merge,copy,clone

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

0
投稿

猜你喜欢

  • 所谓泛型:就是允许在定义类、接口指定类型形参,这个类型形参在将在声明变量、创建对象时确定(即传入实际的类型参数,也可称为类型实参)泛型类或接
  • 今天做统计时需要对X轴的地区按照地区代码(areaCode)进行排序,由于在构建XMLData使用的map来进行数据统计的,所以在统计过程中
  • 一直做Android前端,今天突然心血来潮想搭建一个后台玩玩。平时都是需要什么样的接口直接出个接口文档扔给后台的兄弟,自己从来不操心他们内部
  • 本文实例为大家分享了android实现底部导航栏的具体代码,供大家参考,具体内容如下常见的底部导航栏动态效果实现步骤1.底部导航栏样式我们应
  • 本文通过一个简单的小例子简述SharpZipLib压缩文件的常规用法,仅供学习分享使用,如有不足之处,还请指正。什么是SharpZipLib
  • 1. 支持的视图技术前端模板引擎技术的出现,使前端开发人员无需关注后端业务的具体实现,只关注自己页面的呈现效果即可,并且解决了前端代码错综复
  • 直接来,ResponseDemo1代码,get请求到post请求,重定向到ResponseDemo2我的虚拟目录为ResponseDemo1
  • 投影(Projection) 是一种可以将查询结果进行 塑性 的一种操作,你可以使用 投影 将一个 object 转成仅包含你需要属性的新对
  • 1.user实体package com.demo.dto;public class User {  private Integer
  • java修改JFrame默认字体修改默认字体的方法很简单。首先我们随便写一个按钮出来:import javax.swing.*; publi
  • 对象重复是指对象里面的变量的值都相等,并不定是地址。list集合存储的类型是基础类型还比较好办,直接把list集合转换成set集合就会自动去
  • 一、构造方法概述构造方法是一种特殊的方法作用:创建对象Student stu = new Student();格式:pucli class
  • 本文主要通过彩 * 象灰度化来介绍C#处理数字图像的3种方法,Bitmap类、BitmapData类和Graphics类是C#处理图像的的3个
  • 二维码是越来越流行了,很多地方都有可能是使用到。如果是静态的二维码还是比较好处理的,通过在线工具就可以直接生成一张二维码图片,比如:草料二维
  • 目录前言1、什么是Filter2、过滤器实现拦截过程3、过滤器与 * 的不同之处1.过滤器:2. * :3.两者的区别:4、使用Filter
  • 前言:本文主要介绍内容有:一个串行调用的例子(App首页信息查询)CompletionService实现并行调用抽取通用的并行调用方法代码思
  • 前面文章已经详细介绍了Android界面的入门技术,相信大家在看完和跟着练习之后,会对于常用的Layout和View都会有一定的了解了,接下
  • 本文为大家分析了Java中字符流与字节流的区别,供大家参考,具体内容如下1. 什么是流    Java中的流是
  • 本文实例汇总了winform获取当前名称的方法。分享给大家供大家参考。具体方法如下:// 获取程序的基目录。System.AppDomain
  • 概念Java中的集合就是一种容器,可以容纳不同种类的数据,这些容纳是建立在未知的基础上。优点1.可以动态保存任意多个对象,使用比较方便。2.
手机版 软件编程 asp之家 www.aspxhome.com