首頁 >後端開發 >C++ >如何解決「LINQ to Entities 無法辨識方法『Double.Parse』」錯誤?

如何解決「LINQ to Entities 無法辨識方法『Double.Parse』」錯誤?

Linda Hamilton
Linda Hamilton原創
2024-12-28 22:10:11240瀏覽

How to Resolve the

錯誤解釋:「LINQ to Entities 無法辨識方法'Double Parse(System.String)' 方法,且此方法無法轉換為儲存運算式」

嘗試執行包含實體框架資料庫引擎不支援的方法的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 檔案中的實體 SQL 定義

開啟模型的 *.edmx 檔案並找到 ;元素。在 中加入以下函數定義: element:

    <Function Name="ParseDouble" ReturnType="Edm.Double">
        <Parameter Name="stringvalue" Type="Edm.String" />
        <DefiningExpression>
            cast(stringvalue as Edm.Double)
        </DefiningExpression>
    </Function>

ObjectContext 類別中的自訂方法

接下來,為您的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表達式

定義並實現自訂函數後,您可以更新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中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn