0

LINQ で外部結合ステートメントを作成しようとしていますが、うまくいきません。外部結合を実行するには、次の 2 つの手順が必要であることを知っています。

(1)結合をグループ結合に変換します

(2) グループで DefaultIfEmpty() を使用して、結合された結果セットが空の場合に予想される null 値を生成します。

私は例としてこのコードを使用しています:

var query = (from p in dc.GetTable<Person>()
join pa in dc.GetTable<PersonAddress>() on p.Id equals pa.PersonId into tempAddresses
from addresses in tempAddresses.DefaultIfEmpty()
select new { p.FirstName, p.LastName, addresses.State });

だから私はこれをやろうとしました:

var outerJoin =

    from h in resultHours         
    join u in results on h.Key equals u.Key into outer
    from dictionary in outer.DefaultIfEmpty()
    select new { 

問題は、インテリセンスが select new {} ステートメントで何も認識しないことです。私はあなたを試しました。h.、さらに辞書。

私が直面している問題は、2 つの辞書を外部結合しようとしているということです。これは私がする必要があると言われたことですが、それは好きではないようです。私は明らかに何か間違ったことをしている、または何かを理解していません。

特定の条件下で出力に unitId フィールドがないため、ディクショナリ results.Unit をディクショナリ resultHours.Hours に結合する必要があります。外部結合を行うと、これが解消されるはずです。

結果のコードは次のとおりです。

var results = 

    (from v in VDimUnit     
        join vf in VFactEnergyAllocation on v.UnitKey equals vf.UnitKey
        join vd in VDimGadsEvent on vf.GadsEventKey equals vd.GadsEventKey
        join vt in VDimTime on vf.TimeKey equals vt.TimeKey 
    where typeCodes.Contains(vd.GadsEventTypeCode)
    && vt.YearNum >= (year - 3) && vt.YearNum <= year       
    group vf by new {v.PlantId, v.PhysicalUnitId, v.NetDependableCapacity, v.NetMaximumCapacity, 
    vt.MonthNum} into groupItem     
    select new {groupItem.Key.PlantId, groupItem.Key.PhysicalUnitId, groupItem.Key.NetMaximumCapacity,
    groupItem.Key.MonthNum, PO_HRS = groupItem.Sum(
    x=> (float)x.AllocatedEnergyMwh / groupItem.Key.NetDependableCapacity),
            UO_HRS = groupItem.Sum(x=> (float)x.AllocatedEnergyMwh / groupItem.Key.NetDependableCapacity),
        Unit = groupItem.Count(), groupItem.Key}).ToDictionary(x=> x.Key, x=> x);

resultHours のコードは次のとおりです。

var resultHours = 

    (from vt in VDimTime
        join vf in VFactEnergyAllocation on vt.TimeKey equals vf.TimeKey         
        join vd in VDimGadsEvent on vf.GadsEventKey equals vd.GadsEventKey
        join v in VDimUnit on vf.UnitKey equals v.UnitKey       

    group vt by new {v.PlantId, v.PhysicalUnitId, v.NetDependableCapacity, v.NetMaximumCapacity, 
        vt.MonthNum} into groupItem
    select new {groupItem.Key.PlantId, groupItem.Key.PhysicalUnitId, groupItem.Key.NetMaximumCapacity,
        Hours = groupItem.Count(), groupItem.Key}).ToDictionary(x=> x.Key.ToString(), x=> x.Hours); 

これは現在、私の出力の方法です。外部結合の方法がわかったら変更します。

var finalResults = 

    (from r in results
    orderby r.Key.MonthNum, r.Key.PlantId, r.Key.PhysicalUnitId
    select new {Site = r.Key.PlantId, Unit = r.Key.PhysicalUnitId, r.Key.MonthNum, Numerator = r.Value.PO_HRS, Denominator = 
        resultHours[r.Key.ToString()], Weight = r.Key.NetMaximumCapacity, Data_Indicator = DATA_INDICATOR, 
        Budgeted = budgetedPlannedOutageHrs, Industry_Benchmark = INDUSTRY_BENCHMARK, Comments = comments, 
        Executive_Comments = executiveComments, Fleet_Exec_Comments = fleetExecComments});

私は途方に暮れています。私が見つけた LINQ の外部結合の例は、辞書を結合するときには明らかに適用されません。

4

0 に答える 0