关于Linq Extension方法的Where子句

时间:2013-02-04 22:22:07

标签: c# linq join where

我有以下lambda表达式:

query = query.Join( SecondTableSource,
table1 => new
{
    table1 .Field1,
    table1 .Field2
},
table2 => new
{
    table2 .Field1,
    table2 .Field2
},
( table1 , table2 ) => table1 ) ;

正如您所看到的,我只返回第一个表的结果,但我需要通过table2中的列过滤掉结果。我将如何去做但仍然只回来 IQueryable<table1>

谢谢!

以下是我要转换的原始代码:

query = from table1 in Model.Table1s
    join table2 in Model.Table2s
        on new
        {
            table1.field1,
            table1.field2
        }
    equals
        new
        {
            table2.field1,
            table2.Part
        }
    where table2.field.StartsWith( criteria.value )
    select table1;

我认为我必须没有正确转换,因为发布的前两个答案(这是我写这篇文章的时候发布的所有答案)应该有效,但是当我期待4时返回一个结果(如返回的那样)原始查询)。

2 个答案:

答案 0 :(得分:2)

在你不能之前过滤表2?

query = query.Join(SecondTableSource.Where(table2 => table2.MyFieldToFilter == condition),
                   table1 => ...,
                   ...);

答案 1 :(得分:0)

如果您有更复杂的查询,这是另一种选择......

IEnumerable<MyType1> result = table1.Join(table2,
        t1 => new { t1.Field1, t1.Field2 },
        t2 => new { t2.Field1, t2.Field2 },
        (t1, t2) => new { table1 = t1, table2 = t2 }).
    Where(joinedResults => joinedResults.table2 == //condition).
    Select(filteredResults => filteredResults.table1);