1

この SQL クエリを有効な linq ステートメントに変換できません

select sum(cena), id_auta, max(servis) from dt_poruchy left outer join mt_auta on dt_poruchy.id_auta=mt_auta.id
where dt_poruchy.servis>=3 group by id_auta;

このようなことを試しましたが、選択ステートメントを処理できません

   var auta = from a in MtAuta.FindAll()
                   join p in DtPoruchy.FindAll() on a equals p.MtAuta into ap
                   from ap2 in ap.DefaultIfEmpty()
                   where ap2.SERVIS >= 3
                   group ap2 by ap2.ID into grouped
                   select new {

どんな助けにも感謝します!

4

4 に答える 4

2

提供された限られた情報(どのテーブルからの特定のフィールドですか?)に基づいて、これが私が思いついたものです。

var auta = from a in MtAuta.FindAll()
           let p = a.DtPoruchys.Where(s => s.SERVIS >= 3)
           select new
           {
               Id = a.Id,
               CenaSum = p.Sum(c => c.Cena),
               Servis = p.Max(s => s.SERVIS)
           };
于 2009-07-20T15:11:11.823 に答える
1

どのテーブルのcenaとservisが由来するのかはわかりませんが、グループ化された合計を作成するには、次のようにします。

select new { Sum = grouped.Sum( x => x.cena ) }

と最大を取得するには

select new { Max = grouped.Group.Max( x => x.servis ) }

ここにあなたのための良いリファレンスがあります。

于 2009-07-20T15:08:29.473 に答える
1

私はこの解決策に達しました(「cena」がに属していると仮定しますMtAuta.FindAll()):

        var auta = from e in
                       (from a in DtPoruchy.FindAll()
                        where a.SERVIS >= 3
                        join p in MtAuta.FindAll() on a.MtAuta equals p.Id into ap
                        from ap2 in ap.DefaultIfEmpty()
                        select new
                        {
                            Cena = ap.cena,
                            IdAuta = a.MtAuta,
                            Servis = a.servis
                        })
                   group e by e.IdAuta into g
                   select new
                   {
                       Cena = g.Sum(e => e.cena),
                       IdAuta = g.Key,
                       Servis = g.Max(e => e.servis)
                   };
于 2009-07-20T15:17:33.747 に答える
0

ソリューションを少し変更しましたが、次のように機能します。

var auta = from jo in
                       (
                           from a in MtAuta.FindAll()
                           join p in DtPoruchy.FindAll() on a equals p.MtAuta into ap
                           from ap2 in ap.DefaultIfEmpty()
                           where ap2.SERVIS >= 3
                           select new
                           {
                               Cena = ap2.CENA,
                               Idauto = ap2.ID_AUTA,
                               Servis = ap2.SERVIS
                           }
                       )
                   group jo by jo.Idauto into g
                   select new
                   {
                       Cena = g.Sum(jo => jo.Cena),
                       IdAuto = g.Key,
                       Servis = g.Max(jo => jo.Servis)
                   };

これが最善の解決策であるかどうかだけ知りたいですか?

于 2009-07-20T17:35:05.623 に答える