1. protected void Page_Load(object sender, EventArgs e)
  2. {
  3. DataTable dt = new DataTable();
  4. dt.Columns.Add("col");
  5. for (int i = 5; i >0;i=i-2)
  6. {
  7. DataRow row = dt.NewRow();
  8. row["col"] = "车" + i;
  9. dt.Rows.Add(row);
  10. }
  11. DataTable dt1 = new DataTable();
  12. dt1.Columns.Add("col1");
  13. for (int i = 1; i <= 4; i++)
  14. {
  15. DataRow row = dt1.NewRow();
  16. row["col1"] = "车" + i;
  17. dt1.Rows.Add(row);
  18. }
  19. DataTable resultTable = cf(dt,dt1);
  20. Response.Write("重复:");
  21. for (int i = 0; i < resultTable.Rows.Count; i++)
  22. Response.Write(resultTable.Rows[i]["col"].ToString());
  23. Response.Write("<br/>");
  24. resultTable = bcfbyd1tod2(dt, dt1);
  25. Response.Write("不重复 d1tod2:");
  26. for (int i = 0; i < resultTable.Rows.Count; i++)
  27. Response.Write(resultTable.Rows[i]["col"].ToString());
  28. Response.Write("<br/>");
  29. resultTable = bcfbyd2tod1(dt, dt1);
  30. Response.Write("不重复 d2tod1:");
  31. for (int i = 0; i < resultTable.Rows.Count; i++)
  32. Response.Write(resultTable.Rows[i]["col"].ToString());
  33. Response.Write("<br/>");
  34. }
  35. /// <summary>
  36. /// 取重复
  37. /// </summary>
  38. /// <param name="dt"></param>
  39. /// <param name="dt1"></param>
  40. /// <returns></returns>
  41. private DataTable cf(DataTable dt, DataTable dt1)
  42. {
  43. DataTable myTable = dt.Clone();
  44. for (int i = 0; i < dt.Rows.Count; i++)
  45. {
  46. DataRow[] sRow= dt1.Select("col1='"+dt.Rows[i]["col"].ToString()+"'");
  47. if (sRow.Length > 0)
  48. {
  49. DataRow row= myTable.NewRow();
  50. row["col"] = dt.Rows[i]["col"].ToString();
  51. myTable.Rows.Add(row);
  52. }
  53. }
  54. return myTable;
  55. }
  56. /// <summary>
  57. /// 不重复d1tod2
  58. /// </summary>
  59. /// <param name="dt"></param>
  60. /// <param name="dt1"></param>
  61. /// <returns></returns>
  62. private DataTable bcfbyd1tod2(DataTable dt, DataTable dt1)
  63. {
  64. DataTable myTable = dt.Clone();
  65. for (int i = 0; i < dt.Rows.Count; i++)
  66. {
  67. DataRow[] sRow = dt1.Select("col1='" + dt.Rows[i]["col"].ToString() + "'");
  68. if (sRow.Length == 0)
  69. {
  70. DataRow row = myTable.NewRow();
  71. row["col"] = dt.Rows[i]["col"].ToString();
  72. myTable.Rows.Add(row);
  73. }
  74. }
  75. return myTable;
  76. }
  77. /// <summary>
  78. /// 不重复d1tod2
  79. /// </summary>
  80. /// <param name="dt"></param>
  81. /// <param name="dt1"></param>
  82. /// <returns></returns>
  83. private DataTable bcfbyd2tod1(DataTable dt, DataTable dt1)
  84. {
  85. DataTable myTable = dt.Clone();
  86. for (int i = 0; i < dt1.Rows.Count; i++)
  87. {
  88. DataRow[] sRow = dt.Select("col='" + dt1.Rows[i]["col1"].ToString() + "'");
  89. if (sRow.Length == 0)
  90. {
  91. DataRow row = myTable.NewRow();
  92. row["col"] = dt1.Rows[i]["col1"].ToString();
  93. myTable.Rows.Add(row);
  94. }
  95. }
  96. return myTable;
  97. }
  98. http://blog.csdn.net/yeness/article/details/7817032

两个 DataTable 读取重复数据,dataTable1与dataTable2不同的更多相关文章

  1. 两个 DataTable 读取重复数据

    今天正好用到Excel 导入转换成table , 文件中数据要和数据库里数据进行比对,有重复的抛出重复数据. 和大家分享下,欢迎高手留言指点.有问题可以留言关注! /// <summary> ...

  2. 【转载】C#的Merge方法合并两个DataTable对象的数据

    在C#中的Datatable类中,可以使用DataTable类的Merge方法对两个相同结构的DataTable对象进行求并集运算,将两个DataTable对象的数据行合并到其中一个DataTable ...

  3. C# 两个datatable中的数据快速比较返回交集或差集[z]

    最基本的写法无非是写多层foreach循环,数据量多了,循环的次数是乘积增长的. 这里推荐使用Except()差集.Intersect()交集,具体性能没有进行对比. 如果两个datatable的字段 ...

  4. C# 两个datatable中的数据快速比较返回交集或差集

    转自: https://www.cnblogs.com/lacey/p/5893380.html 如果两个datatable的字段完全一致的话,可以直接使用Except,Intersect //Exc ...

  5. C# 高效过滤DataTable 中重复数据方法

    使用DataView,然后设置ToTable,设置几个字段和一个布尔值,表示这些字段作为一个整体,在这个表内不允许重复,示例代码: namespace A { class Program { stat ...

  6. C# DataTable 去重复数据方法

    //获取dt中Id,Value 2个字段不重复的数据 newDt = dt.DefaultView.ToTable(true, "Id","Value" );

  7. c# 利用IEqualityComparer接口去除DataTable重复数据

    IEqualityComparer主要适用于定义方法以支持对象的相等比较.可以实现集合的自定义相等比较.即,您可以创建自己的相等定义,并指定此定义与接受 IEqualityComparer 接口的集合 ...

  8. 重复数据删除(De-duplication)技术研究(SourceForge上发布dedup util)

    dedup util是一款开源的轻量级文件打包工具,它基于块级的重复数据删除技术,可以有效缩减数据容量,节省用户存储空间.目前已经在Sourceforge上创建项目,并且源码正在不断更新中.该工具生成 ...

  9. JS求多个数组的重复数据

    今天朋友问了我这个问题:JS求多个数组的重复数据 注: 1.更准确的说是只要多个数组中有两个以上的重复数据,那么这个数据就是我需要的 2.单个数组内的数据不存在重复值(当然如果有的话,你可以去重) 3 ...

随机推荐

  1. jquery animated选择器 语法

    jquery animated选择器 语法 作用::animated 选择器选取当前的所有动画元素.直线电机参数 语法:$(":animated") jquery animated ...

  2. POJ 1236 学校传数据 强连通+缩点+DAG

    题意描述: 网络中有一些学校,每个学校可以分发软件给其他学校.可以向哪个分发取决于他们各自维护的一个清单. 两个问题 1:至少要copy多少份新软件给那些学校, 才能使得每个学校都能得到. 2:要在所 ...

  3. codevs 1079 回家x

    1079 回家  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 白银 Silver   题目描述 Description 现在是晚餐时间,而母牛们在外面分散的牧场中. 农民约翰 ...

  4. (49)LINUX应用编程和网络编程之四 Linux进程全解

    补充: 1.  C程序的执行过程: C编译器调用链接器,链接器设置可执行程序文件的启动起始地址(启动例程),启动例程获得内核传递来的 命令行参数和环境变量值,为调用main函数做准备.[实际上该启动例 ...

  5. 从头开始学习Vuex

    一.前言 当我们的应用遇到多个组件共享状态时,会需要多个组件依赖于同一状态抑或是来自不同视图的行为需要变更同一状态.以前的解决办法: a.将数据以及操作数据的行为都定义在父组件; b.将数据以及操作数 ...

  6. Linux读写执行权限

    Linux 将访问文件的用户分为 3 类,分别是文件的所有者,所属组(也就是文件所属的群组)以及其他人. 最常见的文件权限有 3 种,即对文件的读(用 r 表示). 写(用 w 表示). 执行(用 x ...

  7. CentOS7 下 Zabbix3.4 源码安装

    zabbix系统基于PHP环境运行,所以前提是系统上有PHP的运行环境,lnmp或者lamp环境 lnmp环境安装:http://www.cnblogs.com/rnckty/p/7642034.ht ...

  8. Vue知识整理10:条件渲染(v-if v-show)

    在Vue中使用v-if等条件实现条件的判断来实现对象的显示. 也可以采用 v-show条件来实现对象的显示.

  9. $.ajax函数调接口,报异常No converter found for return value of type: class java.util.ArrayList

    接口正常执行,返回给前端后报服务器500异常,异常详情: org.springframework.http.converter.HttpMessageNotWritableException: No ...

  10. 用U盘完成win10系统的安装

    电脑太卡了,每次都要重装,然后每次忘记要从哪里开始动手,都要百度,仅以此篇记录下 目录 1.系统盘准备 2.从U盘启动安装 1.系统盘准备 第一步:在电脑中完成系统盘制作工具的安装,由于它是要依赖.n ...