Maison >base de données >tutoriel mysql >Comment utiliser correctement DbContext.Database.SqlQuery avec les paramètres de procédure stockée ?

Comment utiliser correctement DbContext.Database.SqlQuery avec les paramètres de procédure stockée ?

Susan Sarandon
Susan Sarandonoriginal
2025-01-17 12:06:14534parcourir

How to Correctly Use DbContext.Database.SqlQuery with Stored Procedure Parameters?

EF Code First CTP5 : Utilisation de DbContext.Database.SqlQuery avec les paramètres de procédure stockée(sql, params)

Question :

Les développeurs sont confrontés à des difficultés pour fournir des paramètres lorsqu'ils tentent d'utiliser la méthode DbContext.Database.SqlQuery avec des procédures stockées. Lors de l'utilisation de l'objet SqlParameter, une SqlException est levée, indiquant que le paramètre n'a pas été fourni comme prévu.

Réponse :

Afin d'utiliser avec succès la méthode DbContext.Database.SqlQuery avec une procédure stockée nécessitant des paramètres, l'approche suivante doit être utilisée :

Solution :

Au lieu de transmettre l'objet SqlParameter directement en tant que paramètre, modifiez la chaîne de requête SQL pour inclure les noms de paramètres commençant par le symbole "@". Ensuite, créez et attribuez des instances SqlParameter pour chaque paramètre requis et fournissez-les comme paramètres supplémentaires.

Exemple de code :

L'extrait de code suivant démontre une utilisation correcte :

<code class="language-c#">context.Database.SqlQuery<我的实体类型>(
    "mySpName @param1, @param2, @param3",
    new SqlParameter("param1", param1),
    new SqlParameter("param2", param2),
    new SqlParameter("param3", param3)
);</code>

Cette syntaxe mise à jour devrait résoudre le problème SqlException et vous permettre d'utiliser la méthode DbContext.Database.SqlQuery pour récupérer les résultats souhaités à partir d'une procédure stockée.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn