在 MySQL 到 SQL Server 数据迁移期间,出现一个常见错误:LINQ to Entities 无法识别 System.String ToString()
方法,从而阻止转换为数据库查询。 当比较 LINQ where
子句中的字符串时,通常会发生这种情况。
解决方案涉及将 ToString()
的字符串结果存储在临时变量中,然后再在查询中使用它。这有效地将字符串视为常量,从而实现成功的 SQL 转换。 方法如下:
var strItem = item.Key.ToString(); IQueryable<entity> pages = from p in context.pages where p.Serial == strItem select p;
通过将 item.Key.ToString()
分配给 strItem
,该方法的结果将成为 LINQ to Entities 转换器可以理解的常量值。
或者,按照 Alex 的建议(上下文需要参考),SqlFunctions
帮助器类为 LINQ to Entities 查询提供专门的方法,从而可能消除对临时变量的需要。 有关使用 SqlFunctions
的详细说明,请参阅 Alex 的解决方案。
以上是如何解决'LINQ to Entities 无法识别方法'System.String ToString()'方法”错误?的详细内容。更多信息请关注PHP中文网其他相关文章!