장기 실행 작업을 위한 Entity Framework 시간 초과 문제 및 솔루션
Entity Framework(EF)에서는 함수 가져오기와 같은 장기 실행 작업으로 인해 기본 30초 임계값을 초과하는 시간 초과가 발생할 수 있습니다. 이 문제를 해결하려면 올바른 구성 방법을 이해해야 합니다.
기본 명령 시간 초과 문제 해결
한 가지 방법은 App.Config 파일에서 연결 문자열을 수정하고 "Default Command Timeout=300000"을 추가하는 것입니다. 그러나 예제에서 볼 수 있듯이 이 방법은 작동하지 않습니다. 대신 CommandTimeout을 저장소 클래스에서 직접 설정해야 합니다.
<code class="language-csharp">public IEnumerable<trekmatches> GetKirksFriends() { this.context.CommandTimeout = 180; return this.context.GetKirksFriends(); }</code>
이렇게 하면 관련 작업에 대해 시간 초과가 구체적으로 설정됩니다.
연결 문자열 시간 초과 설정 재정의
연결 문자열에 기본 명령 시간 초과를 지정하면 저장소에 수동으로 설정된 CommandTimeout과 충돌할 수 있다는 점에 유의하는 것이 중요합니다. 이 문제를 방지하려면 연결 문자열에서 시간 초과 설정을 제거하십시오.
버그 및 엔터티 프레임워크 버전
연결 문자열에 기본 명령 시간 초과를 지정하는 데 알려진 EF 버그가 있습니다. 이 버그는 데이터 컨텍스트 개체에 직접 시간 초과를 설정하여 해결할 수 있습니다. 구문은 사용된 EF 버전에 따라 다릅니다.
Entity Framework Core 1.0:
<code class="language-csharp">this.context.Database.SetCommandTimeout(180);</code>
Entity Framework 6:
<code class="language-csharp">this.context.Database.CommandTimeout = 180;</code>
엔티티 프레임워크 5:
<code class="language-csharp">((IObjectContextAdapter)this.context).ObjectContext.CommandTimeout = 180;</code>
Entity Framework 4 이하:
<code class="language-csharp">this.context.CommandTimeout = 180;</code>
이러한 설정을 구현하면 장기 실행 작업 중 EF 시간 초과 문제를 효과적으로 해결할 수 있습니다.
위 내용은 장기 실행 작업에 대한 Entity Framework 시간 초과를 효과적으로 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!