Enumerable に含まれる型がわからないため、Dynamic Linq を使用できるように AsQueryable にしようとしています。例えば:
static string Query(object obj, string expression)
{
var q = ((IEnumerable<object>)obj).AsQueryable();
var a = q.Where(expression, "").First();
return a.ToString();
}
いくつかのことを試すためにテスト プログラム (以下) をセットアップしましたが、その方法がわかりません。タイプ「Object」に「プロパティまたはフィールド「AddressId」がありません」という例外が発生します
Dynamic.cs の Expression ParseMemberAccess(Type type, Expression instance) メソッドで発生します。
System.Linq.Dynamic の使用;
class Address
{
public int AddressId { get; set; }
public string Street { get; set; }
}
class Program
{
static void Main(string[] args)
{
var a = new Address() { AddressId = 1, Street = "10 main st" };
var aList = new List<Address>();
aList.Add(a);
aList.Add(a);
var q1 = aList.AsQueryable();
var a1 = q1.Where(i => i.AddressId == 1).First();
var q2 = aList.AsQueryable();
var a2 = q2.Where("AddressId == @0", 1).First();
object obj3 = aList;
var q3 = ((IEnumerable<Address>)obj3).AsQueryable();
var a3 = q3.Where("AddressId == @0", 1).First();
//This case fails!
object obj4 = aList;
var q4 = ((IEnumerable<object>)obj4).AsQueryable();
var a4 = q4.Where("AddressId == @0", 1).First();
}
}
直接のウィンドウでは、q1、q2、q3、q4 はすべて同じように見えます - EnumerableQuery は型を認識しています...
{System.Collections.Generic.List 1[TestAsQueryable.Address]}
base {System.Linq.EnumerableQuery}: {System.Collections.Generic.List
1[TestAsQueryable.Address]}