我想在LINQ中创建一个带有交叉应用的查询到用户定义的表值函数。 SQL将非常简单,如下所示:
SELECT *
FROM MyTable mt
CROSS APPLY MyTVF(mt.id)
这个 post给出了LINQ查询的示例,该查询导致生成的sql包含交叉应用和外部应用,但仅用于不用于tvf的子查询。 这个 文章确认LINQ to SQL将为“关系导航”生成交叉应用和外部应用运算符,但我不确定在这种情况下这意味着什么。 这个 post几乎描述了我想要做的事情,答案说,执行此操作的唯一方法是将SQL查询包装在存储过程中,然后通过LINQ调用sp。我希望这不是真的,因为我实际上需要一个可以在多个LINQ查询的应用程序中以这种方式使用的tvf,因此“将它包装在sp中”对我来说不起作用。有没有人知道通过LINQ获得类似上面的简单SQL语句的方法?
这个怎么样:
from mt in db.MyTable
from mf in db.MyTVF (mt.id)
select new { mt.Blah, mf.Blah }
var query = ActivityRepository.Where(p => p.iAction > -1 && userIds.Contains(p.iSellerId)).GroupBy(c => c.iSellerId).Select(c => c.OrderByDescending(cc => cc.dBeginTime).First()).Select(a => new ActivityInfo
{
ActivityId = a.iActivityId,
StartTime = a.dBeginTime,
SellerId = a.iSellerId,
EndTime = a.dEndTime,
ActivityName = a.sName,
});
关键点是:.Select(c => c.OrderByDescending(cc => cc.dBeginTime).First())