嘗試執行包含實體框架資料庫引擎不支援的方法的LINQ 表達式時,會發生此錯誤。在本例中,導致錯誤的方法是 Double.Parse(string)。
在提供的程式碼中,在以下語句中遇到錯誤:
model.Referring = Math.Round(_newSurveyResult.Select(m => string.IsNullOrEmpty(m.Question1) ? 0 : Double.Parse(m.Question1)).Average());
實體框架將LINQ 表達式轉換為SQL 查詢以在資料庫上執行。但是,Double.Parse 方法不是標準 SQL 函數,無法直接轉換為 SQL。
要解決此問題,您可以在 Entity 中定義自訂函數可以翻譯為等效的 SQL 表達式的框架模型。在本例中,我們將定義一個名為 ParseDouble 的函數。
開啟模型的 *.edmx 檔案並找到
<Function Name="ParseDouble" ReturnType="Edm.Double"> <Parameter Name="stringvalue" Type="Edm.String" /> <DefiningExpression> cast(stringvalue as Edm.Double) </DefiningExpression> </Function>
接下來,為您的ObjectContext 類別建立一個分部類別並向其中新增以下方法:
using System.Data.Objects.DataClasses; public partial class YourObjectContext { /// <summary> /// This method exists for use in LINQ queries, /// as a stub that will be converted to a SQL CAST statement. /// </summary> [EdmFunction("YourModel", "ParseDouble")] public static double ParseDouble(string stringvalue) { return Double.Parse(stringvalue); } }
定義並實現自訂函數後,您可以更新LINQ 表達式以使用it:
model.Referring = Math.Round(_newSurveyResult.Select(m => string.IsNullOrEmpty(m.Question1) ? 0 : YourObjectContext.ParseDouble(m.Question1)).Average());
現在,LINQ 表達式應該成功轉換為可由資料庫引擎執行的SQL查詢。
以上是如何解決「LINQ to Entities 無法辨識方法『Double.Parse』」錯誤?的詳細內容。更多資訊請關注PHP中文網其他相關文章!