7

我必须使用 linq 从我的 DataTable 中选择特定列 我正在使用此代码

ds.Table[0].AsEnumerable().Where<DataRow>(r=>r.Field<int>("productID")==23).CopyToDataTable();

~

但它给了我所有的专栏,我只需要 PRODUCTNAME , DESCRIPTION , PRICE

我怎么写这个查询?

4

2 回答 2

7

要扩展@lazyberezovsky,您可以使用匿名类型投影来获取所需的所有字段:

ds.Table[0].AsEnumerable()
    .Where<DataRow>(r => r.Field<int>("productID") == 23)
    .Select(r => new { ProductName = r.Field<string>("productName"), 
                       Description = r.Field<string>("description"),
                       Price = r.Field<decimal>("price") });

我不知道您的产品名称、描述和价格字段是什么名称和类型,因此您必须替换它们。

于 2012-05-15T12:48:11.993 回答
7

使用 Select 方法:

ds.Table[0].AsEnumerable()
           .Where<DataRow>(r=>r.Field<int>("productID")==23)
           .Select(r => r.Field<int>("productID"));

更新:如果您需要选择多个列,您可以返回匿名类型:

var query = from row in dt.ds.Table[0].AsEnumerable()
            where row.Field<int>("productID")==23
            select new  {
                           ProductID = x.Field<string>("productID"),
                           Foo = x.Field<string>("foo")
                        };

如果您需要将该数据复制到新表,您将面临问题(CopyToDataTable 需要 DataRow 对象的集合)。请参阅如何:在通用类型 T 不是 DataRow 的情况下实现 CopyToDataTable以解决此问题。

于 2012-05-15T12:41:08.503 回答