ฉันจะรับแถว MAX ที่มี GROUP BY ในแบบสอบถาม LINQ ได้อย่างไร


96

ฉันกำลังมองหาวิธีใน LINQ เพื่อจับคู่ SQL Query ต่อไปนี้

Select max(uid) as uid, Serial_Number from Table Group BY Serial_Number

กำลังมองหาความช่วยเหลือเกี่ยวกับเรื่องนี้จริงๆ ข้อความค้นหาด้านบนได้รับ uid สูงสุดของ Serial Number แต่ละรายการเนื่องจากGroup Byไวยากรณ์

คำตอบ:


95
        using (DataContext dc = new DataContext())
        {
            var q = from t in dc.TableTests
                    group t by t.SerialNumber
                        into g
                        select new
                        {
                            SerialNumber = g.Key,
                            uid = (from t2 in g select t2.uid).Max()
                        };
        }

1
ฉันต้องการที่จะยอมรับทั้งสองเป็นคำตอบ แต่ฉันคิดว่าฉันทำไม่ได้ดังนั้นฉันจึงโหวตให้ทั้งสองคน ขอบคุณ BUNCH !!!
SpoiledTechie.com

70
var q = from s in db.Serials
        group s by s.Serial_Number into g
        select new {Serial_Number = g.Key, MaxUid = g.Max(s => s.uid) }

ฉันต้องการที่จะยอมรับทั้งสองเป็นคำตอบ แต่ฉันคิดว่าฉันทำไม่ได้ดังนั้นฉันจึงโหวตให้ทั้งสองคน ขอบคุณ BUNCH !!!
SpoiledTechie.com

โปรดทราบว่าตัวแปรสำหรับนิพจน์แลมบ์ดาในฟังก์ชัน Max สามารถเป็นอะไรก็ได้ (s => s.uid, tv => tv.uid, asdf => asdf.uid) Linq จะรับรู้โดยอัตโนมัติเมื่อเลือกองค์ประกอบประเภท Serial
Michael

31

ในรูปแบบห่วงโซ่วิธีการ:

db.Serials.GroupBy(i => i.Serial_Number).Select(g => new
    {
        Serial_Number = g.Key,
        uid = g.Max(row => row.uid)
    });

23

ฉันตรวจสอบคำตอบของ DamienG ใน LinqPad แล้ว แทน

g.Group.Max(s => s.uid)

ควรจะเป็น

g.Max(s => s.uid)

ขอขอบคุณ!


10
นี่น่าจะเป็นความคิดเห็นเกี่ยวกับคำตอบของ DamienG
Cᴏʀʏ

11

คำตอบนั้นใช้ได้หากคุณต้องการเพียงสองฟิลด์นี้ แต่สำหรับวัตถุที่ซับซ้อนมากขึ้นวิธีนี้อาจมีประโยชน์:

from x in db.Serials 
group x by x.Serial_Number into g 
orderby g.Key 
select g.OrderByDescending(z => z.uid)
.FirstOrDefault()

... สิ่งนี้จะหลีกเลี่ยง "เลือกใหม่"


ฉันชอบสิ่งนี้ - คุณรู้หรือไม่ว่ามันมีประสิทธิภาพเท่ากับคำตอบอื่น ๆ หรือไม่?
noelicus

คุณใช้ไวยากรณ์การสืบค้นที่นี่จนจบโดยที่คุณเปลี่ยนไปใช้ไวยากรณ์วิธีการ คุณต้อง? รูปแบบไวยากรณ์แบบสอบถามแบบเต็มสำหรับโซลูชันของคุณหรือไม่
เส

0

สามารถทำได้โดยใช้ GroupBy และ SelectMany ใน LINQ lamda expression

var groupByMax = list.GroupBy(x=>x.item1).SelectMany(y=>y.Where(z=>z.item2 == y.Max(i=>i.item2)));
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.