如何去掉datatable的重复行

转载 2015年11月17日 17:29:21


        #region datatable去重
    /**/  /// <summary>
        /// datatable去重
         /// </summary>
        /// <param name="dtSource">需要去重的datatable</param>
        /// <param name="columnNames">依据哪些列去重</param>
        /// <returns></returns>
        public static DataTable GetDistinctTable(DataTable dtSource, params string[] columnNames)
        {
            DataTable distinctTable = dtSource.Clone();
            try
            {
                if (dtSource != null && dtSource.Rows.Count > 0)
                {                  
                    DataView dv = new DataView(dtSource);
                    distinctTable = dv.ToTable(true, columnNames);
                }
            }
            catch (Exception ee)
            {
                MessageBox.Show(ee.ToString());
            }
            return distinctTable;
        }
        
        /**//// <summary>
        /// datatable去重
         /// </summary>
        /// <param name="dtSource">需要去重的datatable</param>
        /// <returns></returns>
        public static DataTable GetDistinctTable(DataTable dtSource)
        {
            DataTable distinctTable = null;
            try
            {
                if (dtSource != null && dtSource.Rows.Count > 0)
                {
                    string[] columnNames = GetTableColumnName(dtSource);
                    DataView dv = new DataView(dtSource);
                    distinctTable = dv.ToTable(true, columnNames);
                }
            }
            catch (Exception ee)
            {
                MessageBox.Show(ee.ToString());
            }
            return distinctTable;
        }
        public static string[] GetTableColumnName(DataTable dt)
        {
            string cols = string.Empty;
            for (int i = 0; i < dt.Columns.Count; i++)
            {
                cols += (dt.Columns[i].ColumnName + ",");
            }
            cols = cols.TrimEnd(',');
            return cols.Split(',');
        }
         



文章转载自: datatable去掉重复行   http://www.studyofnet.com/news/1099.html





DataTable相关操作,筛选,取前N条数据,去重复行,获取指定列数据

#region DataTable筛选,排序返回符合条件行组成的新DataTable或直接用DefaultView按条件返回 /// /// DataTable筛选,...

C#中合并DataTable中重复行

using System; using System.Configuration; using System.Data; using System.Linq; using System.Web; us...

DataTable相关操作,筛选,取前N条数据,去重复行,获取指定列数据

#region DataTable筛选,排序返回符合条件行组成的新DataTable或直接用DefaultView按条件返回 /// /// DataTable筛选,...

ADO.NET 从DataTable中获取某列含有的不重复值的几种方式

 在实际开发过程中也许不少人也遇到过我同样的需求: 需要获取DataTable中某一列或几列的含有的不同值,得到类似SQL中Group By的结果 1、传统做法是遍历DataTable(.N...
  • yl_99
  • yl_99
  • 2015年05月25日 16:52
  • 3315

vs2005针对datatable已经有封装好的去重复方法:

1 //去掉重复行 2 DataView dv = table.DefaultView; 3 table = dv.ToTable(true, new string[] { "name", "code...
  • singgel
  • singgel
  • 2017年04月19日 20:50
  • 165

DataTable select() 的使用;DataTabel中distinct用法去重复的的字段或者记录

DataTabel中distinct 在.NET Framework2.0中,选择DataTable等数据源中的唯一值(类似SQL中Distinct的返回结果)非常简单,如下即可: DataT...

Linq实现DaTaTable或者List里面数据值不重复

在回答论坛有个某列不重复的值为条件获取数据的问题,二

获取对固定列不重复的新DataTable

#region 获取对固定列不重复的新DataTable /// /// 获取对固定列不重复的新DataTable /// /// 含有重复...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:如何去掉datatable的重复行
举报原因:
原因补充:

(最多只允许输入30个字)