我的表达式有问题
我有一个实体
public class User{
public string Username{get;set;}
public int PhoneNumber{get;set;}
public string FIrstName{get;set;}
public string LastName{get;set;}
}
我有一个 DTO
public class DTOUser{
public string Username{get;set;}
public int PhoneNumber{get;set;}
public string FIrstName{get;set;}
public string LastName{get;set;}
}
然后我有一个通用的代码片段
public IList<DTOUser> SelectAll(Expression<Func<DTOUser, bool>> predicate)
{
using (var adc = _conn.GetContext())
{
// what should I do ?? so i can convert Predciate to get all values from Users (Entity)
//it generates an error because predicate can't be cast into Entity User
// var users = adc.Users.All(predicate);
}
}
我想通过传递 LAMBDA 表达式来获取 DTOUser 列表
accountrepo.SelectAll( user => user.firstname.equals ("sample"));
我研究了这个问题并得出结论,因为 DTOUser 和 User 是不同的类型,所以很难将表达式从一种类型转换为另一种类型。
Jon Skeet 提出了一种解决方案:
如何将 Expression<Func<T, DateTime>> 转换为 Expression<Func<T, object>>
但是由于这个解决方案似乎我必须将每个值从 DTOUser 映射到 User 这不会使它更复杂,因为我的 DTOUser 包含超过 15 个属性。
有人可以帮我吗?