2010-08-26 2 views
3

Urgh ... мой LINQ внезапно повернул к худшему !!Запрос LINQ с использованием функций объединения и агрегации

У меня есть две таблицы и вы хотите присоединиться и выполнить агрегатные функции по таблицам.

Во-первых, возможно ли это, я полагаю, и, во-вторых, как мне обрабатывать агрегатные функции? Как часть той же инструкции LINQ?

SQL-оператор будет выглядеть немного так:

SELECT  t1.Col1, t1.Col2, t1.Col3, t2.Col10, 
         t2.Col11, SUM(t2.Col4) AS TotalPurchases, COUNT(t1.Col5) AS ProductCount,t2.Col7, 
         t2.Col6, t2.Col8, t2.Col9 
FROM   t1 INNER JOIN 
         t2 ON t1.Col1 = t2.Col1 AND t1.Col5 = t2.Col5 AND 
         t1.Col2 = t2.Col2 
GROUP BY t1.Col1, t1.Col2, t1.Col3, t2.Col7, t2.Col6, 
         t2.Col8, t2.Col9, t2.Col10, t2.Col11 
HAVING  (t1.Col1 = @p1) AND (t1.Col2 = @p2) AND (t1.Col3 = @p3) 

Очевидно, что «AS» секции могут быть проигнорированы, я могу переименовать те, в контрольной группе.

Любые советы, подсказки, указатели были бы весьма признательны.

ответ

0

Попробуйте сделать что-то, как показано ниже использовать объединения с into ключевыми словами, которые помогут вам достичь вашего TAKS

var query = from t1 in prodDtcx.t1 
      join t2 in prodDtcx.t2 on t1.ID equals t2.ID 
      group t1.col1,t2.col2 by new {col1= t1.col1,col2= t2.col2,col3 = t1.col2} into g 
      where g.col3 >= @variable 
      select new { Col1 = g.col1, Col2 = g.col2}; 

Проверить этот пост более подробно: LINQ Having Clause and Group By with condition

Смежные вопросы