>데이터 베이스 >MySQL 튜토리얼 >SSMS에서는 SQL 쿼리가 빠르지만 C# 애플리케이션에서는 느린 이유는 무엇입니까?

SSMS에서는 SQL 쿼리가 빠르지만 C# 애플리케이션에서는 느린 이유는 무엇입니까?

Susan Sarandon
Susan Sarandon원래의
2025-01-04 07:04:34191검색

Why is my SQL Query Fast in SSMS but Slow in my C# Application?

코드 실행이 애플리케이션에서는 느리지만 SSMS에서는 빠르게 실행됩니다

문제:

SQL Server에서 데이터를 빠르게 반환하는 쿼리 Management Studio(SSMS)는 C#에서 실행할 때 상당한 시간이 걸립니다. application.

코드:

C# 코드는 SqlDataAdapter 및 해당 Fill 메서드를 사용하여 쿼리를 실행합니다.

using (var conn = new SqlConnection(...))
using (var ada = new SqlDataAdapter(...))
{
    ada.Fill(Logs);
}

SSMS 쿼리는 다음과 같습니다. 에서 실행한 것과 동일하다. application.

원인:

실행 시간의 불일치는 애플리케이션과 SSMS에서 매개변수를 처리하는 방식의 차이로 인해 발생합니다. 애플리케이션에서는 AddWithValue 메소드를 사용하여 NVARCHAR 유형의 매개변수를 추가하는 반면, SSMS에서는 매개변수가 VARCHAR로 선언됩니다.

해결책:

해결 방법 이 문제는 다음 중 하나입니다.

  1. 애플리케이션에 매개변수를 추가할 때 유형을 허용하는 생성자를 사용하세요. 코드:
ada.SelectCommand.Parameters.Add("@clientID", SqlDbType.Varchar, 200);
  1. SQL 텍스트에 매개변수를 캐스팅합니다.
where client_id = cast(@clientID as varchar(200))

첫 번째 솔루션은 잠재적인 캐시 오염도 해결하므로 선호됩니다. 문제.

추가 고려 사항:

  • 애플리케이션과 SSMS가 모두 동일한 컴퓨터와 로그인을 사용하고 있는지 확인하세요.
  • 쿼리에서 참조된 테이블에 적절한 인덱스가 있고 SSMS에서 제대로 작동하고 있는지 확인하세요. .
  • 매개변수 캐싱이 쿼리 성능에 미치는 영향을 고려하세요.

위 내용은 SSMS에서는 SQL 쿼리가 빠르지만 C# 애플리케이션에서는 느린 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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