我有以下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时返回一个结果(如返回的那样)原始查询)。
答案 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);