返回一個值當使用實體框架與LINQ我可以代碼,如:
var a = context.Employee.Where(x => x.Name.Equals("Michael")).FirstOrDefault();
我很好奇如何創建匿名LINQ表達式自定義的方法。 我有一個模型類和方法,遵循如何從匿名Linq.Expressions.Expression
public class Employee
{
public int Id { get; set; }
public string Name { get; set; }
}
static T Single<T>(Expression<Func<T, bool>> predicate) where T : class
{
//This is from the database
List<Employee> employees = new List<Employee>
{
new Employee { Id = 1, Name = "Michael" },
new Employee { Id = 2, Name = "Derek" }
};
//I have no idea how to return single value of employees
//var expression = (BinaryExpression)predicate.Body;
//var left = expression.Left.Type.Name;
//Func<T, bool> func = predicate.Compile();
//T value = method(html.ViewData.Model);
//T t = (T)Convert.ChangeType(a, typeof(T));
//Employee emp = (Employee)Convert.ChangeType(t, typeof(Employee));
//var body = predicate.Body;
//var prop = (PropertyInfo)((MemberExpression)predicate.Body).Member;
//var propValue = prop.GetValue(func, null);
//var parameter = Expression.Parameter(typeof(T));
//var property = Expression.Property(parameter, expression.Member.Name);
//var equal = Expression.Equal(property, Expression.Constant(propValue));
//var lambda = Expression.Lambda<Func<T, bool>>(equal, parameter);
return null;
}
調用上面的方法應該是這樣
Employee emp = Single<Employee>(d => d.Name == "Michael");
你有沒有嘗試過'AsQuerable()。Where(predicate).FirstOrDefault'? – Valentin
@Valentin不,我不會。我想要自定義方法。 – derodevil