1

这个使用内连接、左外连接、分组依据和两个计数的查询如何转换为 linq?

SELECT
    c.EndowmentID,
    COUNT(DISTINCT f.CriterionID) AS RequiredCriteria,
    COUNT(r.ChoiceID) AS Response
FROM
    Criteria c
INNER JOIN
    Filters f
ON
    c.ID = f.CriterionID
LEFT OUTER JOIN 
    Responses r
ON
    f.ChoiceID = r.ChoiceID
WHERE
    f.IsRequirement = 1
GROUP BY
    c.EndowmentID;

这是我到目前为止所做的:

            var result =
                from c in context.Criteria
                join f in context.Filters on c.ID equals f.CriterionID
                join r in context.Responses on f.ChoiceID equals r.ChoiceID into resfil
                from rf in resfil.DefaultIfEmpty()
                group rf by c.EndowmentID into grouped
                select new 
                {
                    EndowmentID = grouped.Key,
                    Requirements = grouped.Count(t=>t.CriterionID),
                    Response = grouped.Count(t=>t.ChoiceID)
                };
4

1 回答 1

0

您需要group使用匿名类。这将允许您访问select语句中的所有表

group new { c, f, rf } by c.EndowmentID into grouped

SQL:COUNT(DISTINCT f.CriterionID) AS RequiredCriteria,

这可以通过首先选择f.CriterionID列来编写Distinct()Count()

RequiredCriteria = grouped.Select(x => x.f.CriterionID).Distinct().Count()

SQL:COUNT(r.ChoiceID)

Response = grouped.Select(x => x.rf.ChoiceID).Count()
于 2014-02-18T19:25:36.547 回答