-
C#实现的Table的Merge,以及实现Table的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 }
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式