EF Code First CTP5 : Utilisation de DbContext.Database.SqlQuery avec les paramètres de procédure stockée
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!