>백엔드 개발 >C++ >EF Code First의 저장 프로시저 및 매개 변수와 함께 DbContext.Database.SqlQuery를 올바르게 사용하는 방법은 무엇입니까?

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

Linda Hamilton
Linda Hamilton원래의
2025-01-18 19:07:08680검색

How to Correctly Use DbContext.Database.SqlQuery with Stored Procedures and Parameters in EF Code First?

EF Code First CTP5에서 DbContext.Database.SqlQuery(sql, params) 메서드 및 저장 프로시저 사용

Entity Framework Code First CTP5에는 데이터베이스에 대해 원시 SQL 쿼리를 실행하는 방법을 제공하는 DbContext.Database.SqlQuery<T>(sql, params) 메서드가 도입되었습니다. 그러나 매개변수가 있는 저장 프로시저와 함께 이 메서드를 사용하려고 하면 개발자는 매개변수가 제공되지 않았음을 나타내는 예외가 발생할 수 있습니다.

해결책:

매개변수가 필요한 저장 프로시저와 함께 DbContext.Database.SqlQuery<T>(sql, params)을 성공적으로 사용하려면 매개변수를 SqlParameter 개체로 지정해야 합니다. 올바른 구문은 다음과 같습니다.

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

이 예에서 "내 저장 프로시저 이름"은 저장 프로시저의 이름이고, "param1", "param2", "param3"은 저장 프로시저의 해당 매개변수에 전달될 값입니다. . 이러한 방식으로 매개 변수를 지정하면 SqlQuery 메서드는 실행을 위해 저장 프로시저에 값을 올바르게 제공할 수 있습니다.

위 내용은 EF Code First의 저장 프로시저 및 매개 변수와 함께 DbContext.Database.SqlQuery를 올바르게 사용하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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