2017-02-09 15 views
1

には、以下のケースを検討nullにすることができたときに参加左:LINQのは、等号の左側にあるクラスが

クラスを

public class Nested 
{ 
    public Nested(int id){ Id = id; } 
    public int? Id {get; set;} 
} 

public class Pair 
{ 
    public Nested NestedType {get; set;} 
    public string Name {get; set;} 
} 

public class Match 
{ 
    public int? Id {get; set;} 
    public string Name {get; set;} 
} 

インスタンス

var p1 = new Pair(); 
p1.NestedType = new Nested(1); 
p1.Name = "a";   

var p2 = new Pair(); 
p2.NestedType = null; 
p2.Name = "b"; 

var p3 = new Pair(); 
p3.NestedType = new Nested(3); 
p3.Name = "c"; 

List<Pair> pairs = new List<Pair>() {p1, p2, p3}; 

var m1 = new Match(); 
m1.Id = 1; 
m1.Name = "AA"; 

var m2 = new Match(); 
m2.Id = null; 
m2.Name = "BB"; 

var m3 = new Match(); 
m3.Id = 3; 
m3.Name = "CC"; 

List<Match> matches = new List<Match>(){m1, m2, m3}; 

クエリ

var query = from p in pairs 
      join m in matches on p.NestedType.Id equals m.Id into pm 
      from m in pm.DefaultIfEmpty()        
      select new 
      { 
       PairName = p.Name, 
       MatchId = m != null ? m.Id : null 
       MatchName = m != null ? m.Name : null 
      }; 

p.NestedTypeがnullの場合、クエリはequalsステートメント行で例外をスローします。

達成したいのは、p.NestedTypeがヌルの場合は、nullの値をその代わりに配置する必要があります。あたかもp.NestedTypeが割り当てられているものの、そのIdはnullです。それはできますか?

EDIT:C#5.0を使用する必要があります。

var query = from p in pairs 
      where p.NestedType!=null //Notice the where condition added 
      join m in matches on p.NestedType.Id equals m.Id into pm 
      from m in pm.DefaultIfEmpty() 
      select new 
      { 
       PairName = p.Name, 
       MatchId = m != null ? m.Id : null, 
       MatchName = m != null ? m.Name : null 
      }; 

OR

あなたが取得したい場合は:あなたはあなたのケースで投げnull参照の例外を防止し、これはあなたのケースのために望ましい結果をもたらすかどうかを確認することができますwhere(...)句で

+1

これはまさに[C#のヌル条件演算子](HTTPSであります://msdn.microsoft.com/en-us/library/dn986595.aspx)は - 'on p?.NestedType.Idはm.Idと同じです' –

答えて

1

、すべての左側の値は、たとえば、結果が次のように表示される場合は、Null-Conditional Operator in C# 6.0 +を使用できます。

enter image description here

var query = from p in pairs 
      join m in matches on p?.NestedType?.Id equals m.Id into pm //Notice Null-Conditional operator: p?.NestedType?.Id 
      from m in pm.DefaultIfEmpty() 
      select new 
      { 
       PairName = p.Name, 
       MatchId = m != null ? m.Id : null, 
       MatchName = m != null ? m.Name : null 
      }; 

OR

私たちは以下のコメントとしてC#5でそれを行う必要がある場合は、あなたが行うことができます:

var query = from p in pairs 
      let nestedTypeId = (p != null && p.NestedType != null) ? p.NestedType.Id : null 
      join m in matches on nestedTypeId equals m.Id into pm 
      from m in pm.DefaultIfEmpty() 
      select new 
      { 
       PairName = p.Name, 
       MatchId = m != null ? m.Id : null, 
       MatchName = m != null ? m.Name : null 
      }; 
+0

しかし、これは 'p.NestedType'がある行全体を削除しますヌル。私は実際に行を表示したい - それは結局、左の結合です。 – HeyJude

+0

私はC#5.0を使用する必要があります – HeyJude

+0

@HeyJude C#5の答えが更新されました。あなたを助けることを願っています。 –

関連する問題