如您所知,LINQ to SQL会生成自己的实体。 我尝试从数据库中获取数据并将其放入我自己的实体,即我创建的类中。
当我这样做的时候:
AppData.MyDBDataContext context = new AppData.MyDBDataContext();
List<User> users = (from user in context.Users.Select(x => new User
{
Id = x.Id,
Name = x.Name,
Password = x.Password
}) where user.Password == "123456" select user).ToList();
它有效(User
是我创建的一个类)。
但是当我尝试概括和构建一个强制转换函数时:
User castToUser (DataAccess.AppData.User linqEntity)
{
return new User
{
Id = linqEntity.Id,
Name = linqEntity.Name,
Password = linqEntity.Password
};
}
(DataAccess.AppData.User是LINQ to SQL生成的实体)。
AppData.MyDBDataContext context = new AppData.MyDBDataContext();
List<User> users = (from user in context.Users.Select(x => castToUser(x)) where user.Password == "123456" select user).ToList();
它会抛出错误:Method 'DataAccess.Entities.User castToUser(DataAccess.AppData.User)' has no supported translation to SQL.
错误仅在更改
时出现new User
{
Id = x.Id,
Name = x.Name,
Password = x.Password
}
到castToUser(x),返回相同的东西!
答案 0 :(得分:5)
这是因为l2sql试图提出你的投影的翻译。相反,只需在检索数据后进行投影:
AppData.MyDBDataContext context = new AppData.MyDBDataContext();
List<User> users = context.Users
.Where( u => u.Password == "123456" )
.ToList() // fetch
.Select( u => castToUser( u ));
建议 - 不要混合使用linq样式和扩展方法样式这两种样式。这降低了可读性。