EF Code First CTP5에서 DbContext.Database.SqlQuery
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!