>데이터 베이스 >MySQL 튜토리얼 >저장 프로시저 매개 변수와 함께 DbContext.Database.SqlQuery를 올바르게 사용하는 방법은 무엇입니까?

저장 프로시저 매개 변수와 함께 DbContext.Database.SqlQuery를 올바르게 사용하는 방법은 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-17 12:06:14534검색

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

EF Code First CTP5: 저장 프로시저 매개변수와 함께 DbContext.Database.SqlQuery 사용(sql, params)

질문:

개발자는 저장 프로시저와 함께 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.