3


我正在从 Linq-to-SQL 切换到 Linq-to-Entities,在转换过程中遇到错误“LINQ to Entities 无法识别方法'System.String Format(System.String, System.Object , System.Object)' 方法,并且该方法不能翻译成存储表达式”。以下代码是罪魁祸首。我知道这与我在下面使用的动态类型生成有关。我怎样才能仍然使用动态类型并使用 L2E?

var query = _db.Persons.Where(p => p.PersonId == PersonId);
if (query.Count() > 0)
{
  var data = query.Join(_db.Users, p => p.UserId, u => u.UserId, (p, u) => new
    {
      Id = p.PersonId,
      Name = string.Format("{0} {1}", p.FirstName, p.LastName),
      Phone = p.Phone,
      Email = u.Email
    }).Single();
  return data;
}

编辑: 好的,在@John Hartsock 向我展示了简单的解决方案之后感觉有点愚蠢......
如果我想做一些更复杂的字符串操作怎么办?

4

1 回答 1

5

为什么不是这个?

var query = _db.Persons.Where(p => p.PersonId == PersonId);
if (query.Count() > 0)
{
  var data = query.Join(_db.Users, p => p.UserId, u => u.UserId, (p, u) => new
    {
      Id = p.PersonId,
      Name = p.FirstName + " " + p.LastName,
      Phone = p.Phone,
      Email = u.Email
    }).Single();
  return data;
}

这是一个很好的链接给你

http://msdn.microsoft.com/en-us/library/cc716715.aspx

于 2010-11-22T18:26:01.727 回答