私は、クエリ構文としてLINQのと交換したい、このクエリウィッヒがありますSQL ROW_NUMBER()
select
ii.Id, ii.Name as Supplier,
qi.Price1, qi.Price2, qi.Price3,
case when qi.price1 is null then NULL else ROW_NUMBER() OVER(ORDER BY isNull(qi.price1,1000000) ASC) end AS Price1Order,
case when qi.price2 is null then NULL else ROW_NUMBER() OVER(ORDER BY isNull(qi.price2,1000000) ASC) end AS Price2Order,
case when qi.price3 is null then NULL else ROW_NUMBER() OVER(ORDER BY isNull(qi.price3,1000000) ASC) end AS Price3Order
From dbo.InquiryItems ii
left join dbo.quoteItems qi on ii.Id = qi.QuoteItem_InquiryItem
SQL-クエリ結果:私は必要なのC#で
Id Supplier Price1 Price2 Price3 Price1Order Price2Order Price3Order
1655 Supplier 2 80.00 NULL 40.00 3 NULL 1
1656 Supplier 4 65.00 30.00 42.00 2 1 2
1662 Supplier 1 15.00 35.00 43.00 1 2 3
1670 Supplier 3 250.00 NULL NULL 4 NULL NULL
をこのクエリをIQueryableオブジェクトとして使用します。私は異なる部分(1つまたは複数)のクエリをフィルタリングし、サプライヤ(IdAccount)でグループ化し、価格をSUMする必要があります。この価格は私がランクする必要があります。
return colQuoteItem = from vQuote in this.vQuoteItemOverviews
where vQuote.IdConstructionStageId == ConstructionStageId
group vQuote by new
{
vQuote.IdAccount
} into g
select new vQuoteItemOverviewSum
{
Id = g.Max(x => x.Id),
Price1Order = null, //Here i need the ROW_NUMBER like in the SQL-Syntax
Price2Order = null, //Here i need the ROW_NUMBER like in the SQL-Syntax
Price3Order = null, //Here i need the ROW_NUMBER like in the SQL-Syntax
price1 = g.Sum(x => x.price1),
price2 = g.Sum(x => x.price2),
price3 = g.Sum(x => x.price3),
}
;
ありがとうございます。
可能な重複[行\ _number以上のLINQで(XXXによるパーティション)?](http://stackoverflow.com/questions/9980568/row-number-over-partition-by-xxx-in- linq) – captainsac
少し複雑です、あなたは3つのフィールドにrow_numberを持っています。あなたはこの投稿で最初に提案を試みるかもしれません:http://stackoverflow.com/questions/365086/how-to-project-a-line-number-into-linq-query-results/365127#365127 – Prisoner