我有一个简单的方法,可以从 azure 移动服务中检索表。
public static async List<T>GetDataFromListTable<T>()
{
var data = await MobileService.GetTable<T>().ToListAsync();
return data.Count != 0 ? data : null;
}
这工作正常。
我正在尝试做的是使用另一个方法,该方法采用从服务返回的参数名称并返回该参数的值。到目前为止,我有这个
public static async Task<T> GetDataFromTable<T>(string paramName)
{
var k = Activator.CreateInstance(typeof(T));
var members = typeof(T).GetProperties().Select(t=>t.Name).ToList();
if (!members.Contains(paramName))
return (T)k;
var mn = typeof(T).GetProperties()[members.IndexOf(paramName)];
var data = GetDataFromListTable<T>();
var retval = data.Select(t => t.mn);
}
问题显然是我无法执行 Linq 查询,因为 T 不包含 mn。我也不能使用
var retval = data.Select(t=>t.paramName);
因为 paramname 只是类中成员的字符串表示形式。
简而言之。。。
方法1 具有参数名称,从方法 2 中获取一个列表。从方法 2 返回的列表中,找到参数名称并返回关联的值。
有没有办法做我想做的事情?
你可以做:
var retval = data.Select(t => mn.GetGetMethod().Invoke(t, null));
或
var retval = data.Select(t => mn.GetValue(t, null));
你也可以用这样的东西来简化你的代码(没有测试,对不起):
public static async Task<T> GetDataFromTable<T>(string paramName)
{
var k = Activator.CreateInstance(typeof(T));
var mn = typeof(T).GetProperty(paramName);
if (mn == null)
return (T)k;
var data = GetDataFromListTable<T>();
var retval = data.Select(t => mn.GetGetMethod().Invoke(t, null));
...
}
我认为使用表达式树会更方便,因为您正在使用集合。您的方法签名需要合并T
和TResult
类型,因为它使用的是返回IEnumerable<TResult>
的Select
。
public static async Task<IEnumerable<TResult>> SelectData<T, TResult>(
string propertyName
)
{
if(string.IsNullOrWhiteSpace(propertyName))
{
return Enumerable.Empty<TResult>();
}
var dataTask = GetTableData<T>();
var tType = Expression.Parameter(typeof(T), "t");
var property = Expression.Property(tType, propertyName);
var selectExpression =
Expression.Lambda<Func<T, TResult>>(property, tType)
.Compile();
return (await dataTask).Select(selectExpression);
}
难道不可能这样做吗
var retval = data.Select(t => mn.GetValue(t, null));