LINQで次のSQLクエリに一致する方法を探しています。
Select max(uid) as uid, Serial_Number from Table Group BY Serial_Number
これについて本当に助けを求めています。上記のクエリは、Group By
構文のため、各シリアル番号の最大UIDを取得します。
LINQで次のSQLクエリに一致する方法を探しています。
Select max(uid) as uid, Serial_Number from Table Group BY Serial_Number
これについて本当に助けを求めています。上記のクエリは、Group By
構文のため、各シリアル番号の最大UIDを取得します。
回答:
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()
};
}
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) }
これらの2つのフィールドのみが必要な場合は答えは大丈夫ですが、より複雑なオブジェクトの場合、このアプローチが役立つ可能性があります。
from x in db.Serials
group x by x.Serial_Number into g
orderby g.Key
select g.OrderByDescending(z => z.uid)
.FirstOrDefault()
...これは「新規選択」を回避します