집 >데이터 베이스 >MySQL 튜토리얼 >저장 프로시저 매개 변수와 함께 DbContext.Database.SqlQuery를 올바르게 사용하는 방법은 무엇입니까?
EF Code First CTP5: 저장 프로시저 매개변수와 함께 DbContext.Database.SqlQuery 사용
질문:
개발자는 저장 프로시저와 함께 DbContext.Database.SqlQuery 메서드를 사용하려고 할 때 매개 변수를 제공하는 데 어려움을 겪습니다. SqlParameter 개체를 사용할 때 매개 변수가 예상대로 제공되지 않았음을 나타내는 SqlException이 발생합니다.
정답:
매개변수가 필요한 저장 프로시저와 함께 DbContext.Database.SqlQuery 메서드를 성공적으로 사용하려면 다음 접근 방식을 사용해야 합니다.
해결책:
SqlParameter 개체를 매개변수로 직접 전달하는 대신 "@" 기호로 시작하는 매개변수 이름을 포함하도록 SQL 쿼리 문자열을 수정하세요. 그런 다음 각 필수 매개변수에 대해 SqlParameter 인스턴스를 생성 및 할당하고 이를 추가 매개변수로 제공합니다.
코드 예:
다음 코드 조각은 올바른 사용법을 보여줍니다.
<code class="language-c#">context.Database.SqlQuery<我的实体类型>( "mySpName @param1, @param2, @param3", new SqlParameter("param1", param1), new SqlParameter("param2", param2), new SqlParameter("param3", param3) );</code>
이 업데이트된 구문은 SqlException 문제를 해결하고 DbContext.Database.SqlQuery 메서드를 사용하여 저장 프로시저에서 원하는 결과를 검색할 수 있게 해줍니다.
위 내용은 저장 프로시저 매개 변수와 함께 DbContext.Database.SqlQuery를 올바르게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!