【问题标题】:Error LINQ to Entities does not recognize the method 'System.String ToString()' method, and this method cannot be translated into a store expression [duplicate]错误 LINQ to Entities 无法识别方法“System.String ToString()”方法,并且此方法无法转换为存储表达式 [重复]
【发布时间】:2014-02-17 09:35:42
【问题描述】:

我正在使用 MVC4、Entityframewor 和 Jqgrid,当我从 Database 获取数据时,我遇到了这个错误。你们中的许多人说将 id 字段填充到另一个 var 中,但我没有找到确切的写它的位置,我的数据库中的 id 字段是整数。所以请帮帮我。 u.Id 是我从 EF 访问的 Id 字段,它显示此错误。什么是替代方式,以及将新代码放在哪里。 我的控制器看起来像

public JsonResult GetUserDetails(string sidx="Id", string sord="asc", int page=1, int rows=5)
{

    int pageIndex = Convert.ToInt32(page) - 1;
    int pageSize = rows;
    int totalRecords = db.Users.Count();
    int totalPages = (int)Math.Ceiling((float)totalRecords / (float)pageSize);
    var userdata = db.Users.OrderBy(sidx + " " + sord).Skip(pageIndex * pageSize).Take(pageSize);

    var jsonData = new
    {
        total = totalPages,
        page,
        records = totalRecords,

        rows = (from u in userdata
                select new
                {
                    i = u.Id,
                    cell = new string[]{**u.Id.ToString()**, u.Name,u.Designation,u.City}
                    //cell = new string[] { "", "", "", "" }
                }).ToArray()
    };
    return Json(jsonData);
}

我从过去的一天开始工作,并没有从中得到缓解。

【问题讨论】:

    标签: asp.net-mvc linq entity-framework jqgrid-asp.net


    【解决方案1】:

    方法 ToString() 无法转换为 SQL 查询。所以你有几个选择:

    1. 您可以从 db 中获取完整的实体用户数据并将其映射到 .net 代码中的字符串数组:

      var userdata = db.Users.OrderBy(sidx + " " + sord).Skip(pageIndex * pageSize).Take(pageSize).AsEnumerable();
      
      var jsonData = new
      {
      
          total = totalPages,
          page,
          records = totalRecords,
      
          rows = (
              from u in userdata
              select new
              {
                  i = u.Id,
                  cell = new string[]{**u.Id.ToString()**, u.Name,u.Designation,u.City}
                  //cell = new string[] { "", "", "", "" }
              }).ToArray()
      };
      

    2.你可以使用两个Select(),第一个从db获取数据,第二个映射到你的字符串数组:

    var userdata = db.Users.OrderBy(sidx + " " + sord).Skip(pageIndex * pageSize).Take(pageSize).Select(u=>new{u.Id, u.Name, u.Designation, u.City});
    
    var jsonData = new
    {
    
        total = totalPages,
        page,
        records = totalRecords,
    
        rows = (
            from u in userdata.AsEnumerable()
            select new
            {
                i = u.Id,
                cell = new string[]{u.Id.ToString(), u.Name,u.Designation,u.City}
            }).ToArray()
    };
    

    【讨论】:

    • 谢谢基里尔,它成功了。如果你不介意我会问另一个问题,它是关于 Jqgrid,我将上述数据返回到我的 jqgrid,这在我看来。但他的数据作为一系列值返回,但 JQgrid 根本没有出现。如果您希望我可以将我的项目发送给您,它是一个示例项目。请查看。
    • 我没有使用 jqgrid,但是您可以针对新问题创建新问题,并且有人会为您提出解决方案。
    猜你喜欢
    • 2011-08-19
    • 1970-01-01
    • 1970-01-01
    • 2012-04-21
    相关资源
    最近更新 更多