استعلام LINQ باستخدام وظائف Join و Compregate
-
01-10-2019 - |
سؤال
أورغ ... لقد اتخذت 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" ، يمكنني إعادة تسمية تلك الموجودة في عناصر التحكم.
أي تلميحات ، نصائح ، مؤشرات سيكون موضع تقدير كبير.
المحلول
حاول أن تفعل شيئًا ما أدناه ، واستفد من الوصلات مع 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 وجود شرط ومجموعة مع شرط
لا تنتمي إلى StackOverflow