Table Per Hierarchy 継承を使用したエンティティ モデルへの LINQ があります。基本型に対するクエリがあり、特定の型依存のロジックを実行したいと考えています。例えば:
IQueryable<BaseType> base = ...
// this works fine
var result = base.Select(b => b is DerivedType1 ? 1 : 2).ToList();
// this doesn't compile to SQL
var result2 = base.Select(b => b is DerivedType1 ? ((DerivedType1)b).DerivedProperty : null).ToList();
各派生型の IQueryables を個別に処理せずに、このようなことを行う方法はありますか?
// I'd rather not do this:
var resultA = base.OfType<DerivedType1>().Select(d => d.DerivedProperty);
var resultB = base.OfType<DerivedType2>().Select(d => default(int?));
var result = resultA.Concat(resultB).ToList();