同等のGetPropValue< T> L2Eのメソッド?
-
05-07-2019 - |
質問
データモデルにEFを使用すると問題が発生します。
メソッドに次のコードがあります:
listaPaginada = sortOrder.Equals("asc") ?
_cadastroServ.SelecionaNotasFiscais(idParceiro).OrderBy(i => i.GetType().GetProperty(query)) :
_cadastroServ.SelecionaNotasFiscais(idParceiro).OrderByDescending(i => i.GetType().GetProperty(query));
i´ mは同じ方法を使用します:
Func<NotaFiscal, bool> whereClause = (i => i.GetPropValue<string>(sortName).Contains(query));
listaPaginada = sortOrder.Equals("asc", StringComparison.CurrentCultureIgnoreCase) ?
_cadastroServ.SelecionaNotasFiscais(idParceiro).Where(whereClause).OrderByDescending(i => i.GetPropValue<IComparable>(sortName)) :
_cadastroServ.SelecionaNotasFiscais(idParceiro).Where(whereClause).OrderBy(i => i.GetPropValue<IComparable>(sortName));
L2SQLにはGetPropValueメソッドが存在しますが、L2Eには存在しません。
L2Eで同様の方法を知っている人はいますか? またはこれを解決する方法を知っていますか?
よろしく[]
解決
LINQ-to-SQLの GetPropValue
に慣れていません。本当に存在しますか?とは言っても、このメソッドが何をしているのかを思い起こさせ、それに応じて書くのは簡単です:
static class ObjectExtensions {
public static T GetPropValue<T>(this object value, string propertyName) {
if (value == null) { throw new ArgumentNullException("value"); }
if (String.IsNullOrEmpty(propertyName)) { throw new ArgumentException("propertyName"); }
PropertyInfo info = value.GetType().GetProperty(propertyName);
return (T)info.GetValue(value, null);
}
}
使用法:
public class Test {
public string Name { get; set; }
public int Number { get; set; }
}
Test test = new Test() { Name = "Jenny", Number = "8675309" };
Console.WriteLine(test.GetPropValue<string>("Name"));
Console.WriteLine(test.GetPropValue<int>("Number"));
所属していません StackOverflow