184

我有一个数据集 objds。objds 包含一个名为 Table1 的表。表 1 包含名为 ProcessName 的列。这个 ProcessName 包含重复的名称。所以我只想选择不同的名称。这可能吗?

  intUniqId[i] = (objds.Tables[0].Rows[i]["ProcessName"].ToString());
4

18 回答 18

380
DataView view = new DataView(table);
DataTable distinctValues = view.ToTable(true, "Column1", "Column2" ...);
于 2009-07-29T12:37:51.920 回答
164

以下单行代码将避免 a 的重复行DataTable

dataTable.DefaultView.ToTable(true, "employeeid");

在哪里:

  • 第一个参数 inToTable()是一个布尔值,指示您是否需要不同的行。

  • 中的第二个参数ToTable()是我们必须选择不同行的列名。只有这些列将在返回的数据表中。

DataSet通过访问特定的 ,可以从 a 完成相同的操作DataTable

dataSet.Tables["Employee"].DefaultView.ToTable(true, "employeeid");
于 2011-06-29T08:48:40.020 回答
63
DataTable dt = new DataTable();
dt.Columns.Add("IntValue", typeof(int));
dt.Columns.Add("StringValue", typeof(string));
dt.Rows.Add(1, "1");
dt.Rows.Add(1, "1");
dt.Rows.Add(1, "1");
dt.Rows.Add(2, "2");
dt.Rows.Add(2, "2");

var x = (from r in dt.AsEnumerable()
        select r["IntValue"]).Distinct().ToList();
于 2009-07-29T10:14:51.770 回答
36

使用 LINQ(.NET 3.5、C# 3)

var distinctNames = ( from row in DataTable.AsEnumerable()
 select row.Field<string>("Name")).Distinct();

 foreach (var name in distinctNames ) { Console.WriteLine(name); }
于 2011-07-29T05:51:47.337 回答
18

你可以这样使用:

dataDataTable

data.DefaultView.ToTable(true, "Id", "Name", "Role", "DC1", "DC2", "DC3", "DC4", "DC5", "DC6", "DC7");  

但性能会下降。尝试使用以下代码:

data.AsEnumerable().Distinct(System.Data.DataRowComparer.Default).ToList();  

性能;http://onerkaya.blogspot.com/2013/01/distinct-dataviewtotable-vs-linq.html

于 2013-04-06T11:57:13.200 回答
14
var distinctRows = (from DataRow dRow in dtInventory.Rows
                                select dRow["column_name"] ).Distinct();

var distinctRows = (from DataRow dRow in dtInventory.Rows
                                select dRow["col1"], dRow["col2"].. ).Distinct();
于 2012-06-05T15:37:02.107 回答
10

为了改进上述答案:dataview 上的 ToTable 函数有一个“distinct”标志。

//This will filter all records to be distinct
dt = dt.DefaultView.ToTable(true);
于 2009-08-26T19:40:02.420 回答
5

以下作品。我使用 .NET 3.5 SP1 为我工作

// Create the list of columns
String[] szColumns = new String[data.Columns.Count];
for (int index = 0; index < data.Columns.Count; index++)
{
    szColumns[index] = data.Columns[index].ColumnName;
}

// Get the distinct records
data = data.DefaultView.ToTable(true, szColumns);
于 2012-07-11T01:11:16.987 回答
3

我碰巧发现了这个: http: //support.microsoft.com/default.aspx ?scid=kb;en-us;326176#1

在寻找类似的东西时,仅针对.net 2.0

我假设 OP 在使用 DataTable.Select() 时正在寻找不同的东西。(Select() 不支持 distinct)

所以这是上面链接中的代码:

class DataTableHelper 
{
    public DataTable SelectDistinct(string TableName, DataTable SourceTable, string FieldName)
    {   
        DataTable dt = new DataTable(TableName);
        dt.Columns.Add(FieldName, SourceTable.Columns[FieldName].DataType);

        object LastValue = null; 
        foreach (DataRow dr in SourceTable.Select("", FieldName))
        {
            if (  LastValue == null || !(ColumnEqual(LastValue, dr[FieldName])) ) 
            {
                LastValue = dr[FieldName]; 
                dt.Rows.Add(new object[]{LastValue});
            }
        }

        return dt;
    }

    private bool ColumnEqual(object A, object B)
    {

        // Compares two values to see if they are equal. Also compares DBNULL.Value.
        // Note: If your DataTable contains object fields, then you must extend this
        // function to handle them in a meaningful way if you intend to group on them.

        if ( A == DBNull.Value && B == DBNull.Value ) //  both are DBNull.Value
            return true; 
        if ( A == DBNull.Value || B == DBNull.Value ) //  only one is DBNull.Value
            return false; 
        return ( A.Equals(B) );  // value type standard comparison
    }
}
于 2010-12-01T17:05:27.137 回答
3

句法:-

DataTable dt = ds.Tables[0].DefaultView.ToTable(true, "ColumnName");

前任:-

DataTable uniqueCols = dsUDFlable.Tables[0].DefaultView.ToTable(true, "BorrowerLabelName");
于 2014-05-26T11:23:15.260 回答
3
string[] TobeDistinct = {"Name","City","State"};
DataTable dtDistinct = GetDistinctRecords(DTwithDuplicate, TobeDistinct);

//Following function will return Distinct records for Name, City and State column.
public static DataTable GetDistinctRecords(DataTable dt, string[] Columns)
{
    DataTable dtUniqRecords = new DataTable();
    dtUniqRecords = dt.DefaultView.ToTable(true, Columns);
    return dtUniqRecords;
}
于 2015-09-14T05:39:20.577 回答
2
var ValuetoReturn = (from Rows in YourDataTable.AsEnumerable()
select Rows["ColumnName"]).Distinct().ToList();
于 2012-09-04T07:36:43.933 回答
2

最简单的解决方案是使用 LINQ,然后将结果转换为 DataTable

    //data is a DataTable that you want to change
    DataTable result = data.AsEnumerable().Distinct().CopyToDataTable < DataRow > ();

这仅对 asp.net 4.0 ^ 框架有效,并且它需要引用 System.Data.DataSetExtensions正如 Ivan Ferrer Villa 指出的那样

于 2018-01-31T13:49:58.213 回答
2

这很容易

    DataView view = new DataView(dt);
DataTable dt2 = view.ToTable(true, "Column1", "Column2","Column3", ...,"ColumnNth");

和 dt2 数据表包含 column1,Column2..ColumnNth 唯一数据。

于 2018-08-16T10:05:28.207 回答
1
DataTable dt = new DataTable("EMPLOYEE_LIST");

DataColumn eeCode = dt.Columns.Add("EMPLOYEE_CODE", typeof(String));
DataColumn taxYear = dt.Columns.Add("TAX_YEAR", typeof(String));
DataColumn intData = dt.Columns.Add("INT_DATA", typeof(int));
DataColumn textData = dt.Columns.Add("TEXT_DATA", typeof(String));

dt.PrimaryKey = new DataColumn[] { eeCode, taxYear };

它过滤具有 eecode 和 taxyear 的数据表,并被认为是唯一的

于 2015-12-02T12:20:05.160 回答
0
objds.Table1.Select(r => r.ProcessName).AsEnumerable().Distinct();
于 2018-12-14T09:37:11.550 回答
-1
DataTable dtbs = new DataTable(); 
DataView dvbs = new DataView(dt); 
dvbs.RowFilter = "ColumnName='Filtervalue'"; 
dtbs = dvbs.ToTable();
于 2017-06-21T07:30:08.347 回答
-2

像什么?

SELECT DISTINCT .... FROM table WHERE 条件

http://www.felixgers.de/teaching/sql/sql_distinct.html

注意:作业问题?上帝保佑谷歌..

http://www.google.com/search?hl=en&rlz=1C1GGLS_enJO330JO333&q=c%23+selecting+distinct+values+from+table&aq=f&oq=&aqi=

于 2009-07-29T10:14:22.223 回答