Heim >Datenbank >MySQL-Tutorial >Wie übergebe ich Parameter mithilfe von DbContext.Database.SqlQuery korrekt an gespeicherte Prozeduren?

Wie übergebe ich Parameter mithilfe von DbContext.Database.SqlQuery korrekt an gespeicherte Prozeduren?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2025-01-17 12:12:10120Durchsuche

How to Correctly Pass Parameters to Stored Procedures using DbContext.Database.SqlQuery?

Verwenden Sie DbContext.Database.SqlQueryum gespeicherte Prozeduren abzufragen

In Entity Framework Code First CTP5 können Sie die Methode DbContext.Database.SqlQuery<T>(sql, params) verwenden, um eine gespeicherte Prozedur auszuführen. Bei der Übergabe von Parametern an gespeicherte Prozeduren, die genaue Parameternamen erfordern, können jedoch Probleme auftreten.

Um dieses Problem zu beheben, sollten Sie eine SqlParameter-Instanz im folgenden Format bereitstellen:

<code class="language-csharp">context.Database.SqlQuery<我的实体类型>(
    "我的存储过程名称 @param1, @param2, @param3",
    new SqlParameter("param1", param1),
    new SqlParameter("param2", param2),
    new SqlParameter("param3", param3)
);</code>

Dadurch wird sichergestellt, dass die Parameter korrekt mit ihren Namen in der gespeicherten Prozedur übereinstimmen. Durch die explizite Angabe des Parameternamens können Sie den Fehler „Prozedur oder Funktion ‚Mein gespeicherter Prozedurname‘ erfordert den Parameter ‚@param1‘, wurde aber nicht bereitgestellt“ vermeiden.

Mit dieser Methode können Sie gespeicherte Prozeduren dynamisch und stark typisiert abfragen, sodass Sie Entity Framework problemlos zum Abrufen von Daten aus komplexen Datenbankvorgängen verwenden können.

Das obige ist der detaillierte Inhalt vonWie übergebe ich Parameter mithilfe von DbContext.Database.SqlQuery korrekt an gespeicherte Prozeduren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn