質問

urgh ...私のlinqは突然悪化しました!!

2つのテーブルがあり、テーブル上で集計関数を結合して実行したいと考えています。

第一に、これは可能ですか、私はそれがそうであると仮定しています、そして第二に、私は集約関数をどのように処理するのですか?同じ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」セクションは無視でき、コントロールのそれらを変更できます。

ヒント、ヒント、ポインターは大歓迎です。

役に立ちましたか?

解決

以下のように何かをしてみてください into キーワードは、あなたがあなたのテイクを達成するのに役立ちます

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

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top