首頁 > 資料庫 > mysql教程 > 如何在C#中正確呼叫SQL使用者定義函數(UDF)?

如何在C#中正確呼叫SQL使用者定義函數(UDF)?

Barbara Streisand
發布: 2024-12-21 05:56:09
原創
171 人瀏覽過

How to Correctly Invoke SQL User-Defined Functions (UDFs) from C#?

將SQL 定義的函數合併到C# 程式碼:UDF 呼叫故障排除

在C# 中實作使用者定義的SQL 函數(UDF ) 時,開發人員可以將這些函數整合到程式碼中時遇到問題。一個常見的挑戰是從 C# 應用程式中正確呼叫 UDF。

考慮以下情境:開發人員定義了一個名為 Tcupom 的 TSQL 標量函數,用於計算特定訂單的總值。為了從 C# 呼叫此函數,開發人員編寫了以下程式碼:

public void TotalCupom(int cupom)
{ 
    float SAIDA;           
    SqlDataAdapter da2 = new SqlDataAdapter();
    if (conex1.State == ConnectionState.Closed)
    { 
        conex1.Open();
    }
    SqlCommand Totalf = new SqlCommand("Tcupom", conex1);
    SqlParameter code1 = new SqlParameter("@code", SqlDbType.Int);
    code1.Value = cupom ;
    Totalf.CommandType = CommandType.StoredProcedure ;
    SAIDA = Totalf.ExecuteScalar();

    return SAIDA;
}
登入後複製

但是,在執行時,此程式碼無法檢索預期結果。要解決此問題,開發人員必須解決其程式碼中的幾個關鍵問題:

1.直接呼叫UDF:

直接呼叫UDF名稱,例如SqlCommand物件中的“Tcupom”,是不正確的。若要從 C# 呼叫 UDF,必須將其包含在內聯 SQL 語句中。

2. CommandType 錯誤配置:

程式碼錯誤地指定了 CommandType.StoredProcedure,這表示該函數是預存程序。但是,UDF 是與預存程序不同的實體。

3.缺少資料庫範圍:

在內聯 SQL 語句中,函數名稱必須完全符合資料庫架構。例如,「SELECT dbo.Tcupom(@code)」。

4。同步調用:

雖然程式碼似乎透過將結果分配給 SAIDA 來非同步執行函數調用,但 ExecuteScalar() 方法本質上是同步的。若要執行非同步調用,請使用 BeginExecuteReader 或其他非同步方法。

修正的程式碼:

以下修正的程式碼包含必要的變更:

public void TotalCupom(int cupom)
{ 
    float SAIDA;           
    SqlDataAdapter da2 = new SqlDataAdapter();
    if (conex1.State == ConnectionState.Closed)
    {
        conex1.Open();
    }
    SqlCommand Totalf = new SqlCommand("SELECT dbo.Tcupom(@code)", conex1);
    SqlParameter code1 = new SqlParameter("@code", SqlDbType.Int);
    code1.Value = cupom;
    SAIDA = (float)Totalf.ExecuteScalar();

    return SAIDA;
}
登入後複製

以上是如何在C#中正確呼叫SQL使用者定義函數(UDF)?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板