两个 DataTable 读取重复数据,dataTable1与dataTable2不同
- protected void Page_Load(object sender, EventArgs e)
- {
- DataTable dt = new DataTable();
- dt.Columns.Add("col");
- for (int i = 5; i >0;i=i-2)
- {
- DataRow row = dt.NewRow();
- row["col"] = "车" + i;
- dt.Rows.Add(row);
- }
- DataTable dt1 = new DataTable();
- dt1.Columns.Add("col1");
- for (int i = 1; i <= 4; i++)
- {
- DataRow row = dt1.NewRow();
- row["col1"] = "车" + i;
- dt1.Rows.Add(row);
- }
- DataTable resultTable = cf(dt,dt1);
- Response.Write("重复:");
- for (int i = 0; i < resultTable.Rows.Count; i++)
- Response.Write(resultTable.Rows[i]["col"].ToString());
- Response.Write("<br/>");
- resultTable = bcfbyd1tod2(dt, dt1);
- Response.Write("不重复 d1tod2:");
- for (int i = 0; i < resultTable.Rows.Count; i++)
- Response.Write(resultTable.Rows[i]["col"].ToString());
- Response.Write("<br/>");
- resultTable = bcfbyd2tod1(dt, dt1);
- Response.Write("不重复 d2tod1:");
- for (int i = 0; i < resultTable.Rows.Count; i++)
- Response.Write(resultTable.Rows[i]["col"].ToString());
- Response.Write("<br/>");
- }
- /// <summary>
- /// 取重复
- /// </summary>
- /// <param name="dt"></param>
- /// <param name="dt1"></param>
- /// <returns></returns>
- private DataTable cf(DataTable dt, DataTable dt1)
- {
- DataTable myTable = dt.Clone();
- for (int i = 0; i < dt.Rows.Count; i++)
- {
- DataRow[] sRow= dt1.Select("col1='"+dt.Rows[i]["col"].ToString()+"'");
- if (sRow.Length > 0)
- {
- DataRow row= myTable.NewRow();
- row["col"] = dt.Rows[i]["col"].ToString();
- myTable.Rows.Add(row);
- }
- }
- return myTable;
- }
- /// <summary>
- /// 不重复d1tod2
- /// </summary>
- /// <param name="dt"></param>
- /// <param name="dt1"></param>
- /// <returns></returns>
- private DataTable bcfbyd1tod2(DataTable dt, DataTable dt1)
- {
- DataTable myTable = dt.Clone();
- for (int i = 0; i < dt.Rows.Count; i++)
- {
- DataRow[] sRow = dt1.Select("col1='" + dt.Rows[i]["col"].ToString() + "'");
- if (sRow.Length == 0)
- {
- DataRow row = myTable.NewRow();
- row["col"] = dt.Rows[i]["col"].ToString();
- myTable.Rows.Add(row);
- }
- }
- return myTable;
- }
- /// <summary>
- /// 不重复d1tod2
- /// </summary>
- /// <param name="dt"></param>
- /// <param name="dt1"></param>
- /// <returns></returns>
- private DataTable bcfbyd2tod1(DataTable dt, DataTable dt1)
- {
- DataTable myTable = dt.Clone();
- for (int i = 0; i < dt1.Rows.Count; i++)
- {
- DataRow[] sRow = dt.Select("col='" + dt1.Rows[i]["col1"].ToString() + "'");
- if (sRow.Length == 0)
- {
- DataRow row = myTable.NewRow();
- row["col"] = dt1.Rows[i]["col1"].ToString();
- myTable.Rows.Add(row);
- }
- }
- return myTable;
- }
- http://blog.csdn.net/yeness/article/details/7817032
两个 DataTable 读取重复数据,dataTable1与dataTable2不同的更多相关文章
- 两个 DataTable 读取重复数据
今天正好用到Excel 导入转换成table , 文件中数据要和数据库里数据进行比对,有重复的抛出重复数据. 和大家分享下,欢迎高手留言指点.有问题可以留言关注! /// <summary> ...
- 【转载】C#的Merge方法合并两个DataTable对象的数据
在C#中的Datatable类中,可以使用DataTable类的Merge方法对两个相同结构的DataTable对象进行求并集运算,将两个DataTable对象的数据行合并到其中一个DataTable ...
- C# 两个datatable中的数据快速比较返回交集或差集[z]
最基本的写法无非是写多层foreach循环,数据量多了,循环的次数是乘积增长的. 这里推荐使用Except()差集.Intersect()交集,具体性能没有进行对比. 如果两个datatable的字段 ...
- C# 两个datatable中的数据快速比较返回交集或差集
转自: https://www.cnblogs.com/lacey/p/5893380.html 如果两个datatable的字段完全一致的话,可以直接使用Except,Intersect //Exc ...
- C# 高效过滤DataTable 中重复数据方法
使用DataView,然后设置ToTable,设置几个字段和一个布尔值,表示这些字段作为一个整体,在这个表内不允许重复,示例代码: namespace A { class Program { stat ...
- C# DataTable 去重复数据方法
//获取dt中Id,Value 2个字段不重复的数据 newDt = dt.DefaultView.ToTable(true, "Id","Value" );
- c# 利用IEqualityComparer接口去除DataTable重复数据
IEqualityComparer主要适用于定义方法以支持对象的相等比较.可以实现集合的自定义相等比较.即,您可以创建自己的相等定义,并指定此定义与接受 IEqualityComparer 接口的集合 ...
- 重复数据删除(De-duplication)技术研究(SourceForge上发布dedup util)
dedup util是一款开源的轻量级文件打包工具,它基于块级的重复数据删除技术,可以有效缩减数据容量,节省用户存储空间.目前已经在Sourceforge上创建项目,并且源码正在不断更新中.该工具生成 ...
- JS求多个数组的重复数据
今天朋友问了我这个问题:JS求多个数组的重复数据 注: 1.更准确的说是只要多个数组中有两个以上的重复数据,那么这个数据就是我需要的 2.单个数组内的数据不存在重复值(当然如果有的话,你可以去重) 3 ...
随机推荐
- IdentityServer4
序言 IdentityServer4能做什么 Identity Server 4(以下简称ID4)是一个基于oauth2和OpenID的身份认证组件,基于这个组件可以快速开发自己的身份认证网站,支持单 ...
- UVa 11235 Frequent values (RMQ && 区间出现最多次的数的次数)
题意 : 给出一个长度为 n 的不降序序列,并且给出 q 个形如(L, R)的问询,问你这个区间出现的最多次的数的次数. 分析 : 很自然的想到将区间“缩小”,例如1 1 2 3 3 3就可以变成2 ...
- 【gym102394A】Artful Paintings(差分约束系统,二分)
题意:给定一个长为n的序列,每个位置可以选择取或不取,要求构造方案使得: 1.对于前M1个约束,区间[L,R]内取的数量必须严格不少于K 2.对于后M2个约束,区间[L,R]外取的数量必须严格不少于K ...
- 洛谷P3943 星空——题解
一道很好的锻炼思维难度的题,如果您能在考场上直接想出来的话,提高组450分以上就没问题了吧.(别像作者一样看了好几篇题解才勉强会) 先提取出题目大意:给定一个长度n<=40000的01串,其中1 ...
- (61)C语言预处理命令详解
一 前言 预处理(或称预编译)是指在进行编译的第一遍扫描(词法扫描和语法分析)之前所作的工作.预处理指令指示在程序正式编译前就由编译器进行的操作,可放在程序中任何位置. 预处理是C语言的一个重要功能 ...
- java web程序上传文件,浏览器显示连接被重置
上传文件时,到13%时浏览器显示连接被重置如图: 参考网上很多方法 比如设置server.xml 的相应大小.时间,然并没有解决问题 connectionTimeout="2000000&q ...
- 大哥带的MSsql注入(SQL Server)--预习
①判断数据库类型and exists (select * from sysobjects)--返回正常为mssql(也名sql server)and exists (select count(*) f ...
- flask中request对象获取参数的方法
从当前request获取内容: method: 起始行,元数据 host: 起始行,元数据 path: 起始行,元数据 environ: 其中的 SERVER_PROTOCOL 是起始行,元数据 he ...
- 使用http-server在本地搭建一个HTTP服务器
安装http-server 在控制台中输入 npm install http-server -g 进行全局安装 共享资源 进入需要共享资源的目录,比如 D:\,然后在控制台中输入 http-serve ...
- Spring Data JPA学习笔记
下面先来介绍一下JPA中一些常用的查询操作: //And --- 等价于 SQL 中的 and 关键字,比如 findByHeightAndSex(int height,char sex): publ ...