首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用AsEnumerable重构代码

使用AsEnumerable重构代码
EN

Stack Overflow用户
提问于 2017-12-23 03:49:35
回答 2查看 66关注 0票数 0

我有以下代码:

代码语言:javascript
复制
var results = from table1 in ds.Tables[0].AsEnumerable()
join table2 in ds.Tables[1].AsEnumerable()
on table1["VendorNumber"] equals table2["VendorNumber"]
join table3 in ds.Tables[2].AsEnumerable()
on table1["VendorNumber"] equals table3["VendorNumber"]
select new
{ (select clause removed to save space here };

我试图将其重构为一个方法,但当我这样做时,它给了我错误。重构后的方法的第一行是:

代码语言:javascript
复制
private static IEnumerable<> Enumerable(DataSet ds)

我得到的错误是“未绑定的泛型名称的意外使用”。

我需要做些什么才能正确地将这些代码重构成一个方法,有什么建议吗?谢谢!

EN

回答 2

Stack Overflow用户

发布于 2017-12-23 08:55:39

看起来您正在使用ADO.NetDataSet获取表,并尝试使用LINQ将这些表连接在一起。你不能这么做。应该将DataTable中的每个DataRow转换为与其包含的数据等效的对象。然后,您可以在对象上连接。例如,如果其中一个DataTable包含Foo数据:

代码语言:javascript
复制
public class Foo
{
    public int FooId { get; }

    public int BarId { get; }

    public Foo(DataRow row)
    {
        FooId = row.Field<int>(nameof(FooId));
        BarId = row.Field<int>(nameof(BarId));
    }
}

另一个DataTable包含Bar数据:

代码语言:javascript
复制
public class Bar
{
    public int BarId { get; }

    public Bar(DataRow row)
    {
        BarId = row.Field<int>(nameof(BarId));
    }
}

然后将它们连接到一个匿名FooBar对象的IEnumerable中,如下所示:

代码语言:javascript
复制
var ds = new DataSet();

var foos = ds.Tables[0].Rows.OfType<DataRow>().Select(dr => new Foo(dr));
var bars = ds.Tables[1].Rows.OfType<DataRow>().Select(dr => new Bar(dr));

var foobars = from foo in foos
              join bar in bars
              on foo.BarId equals bar.BarId
              select new { Foo = foo, Bar = bar};

您可以改用ValueTuple

代码语言:javascript
复制
var foobars = from foo in foos
              join bar in bars
              on foo.BarId equals bar.BarId
              select (Foo: foo, Bar: bar);

顺便说一下,.Field<T>扩展是用System.Data.DataSetExtensions编写的!

票数 0
EN

Stack Overflow用户

发布于 2017-12-23 13:16:37

您需要指定集合元素的类型或使用类型参数

代码语言:javascript
复制
private static IEnumerable<T> Enumerable(DataSet ds)
{
    // function body here
}

在本例中,该函数返回DataRow元素的集合(请参见DataTableExtensions.AsEnumerable Method description。所以,你可以使用

代码语言:javascript
复制
private static IEnumerable<DataRow> Enumerable(DataSet ds)
{
    // function body here
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/47946660

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档