다음을 통해 공유


LINQ를 사용하여 C#에서 데이터 필터링

필터링은 지정된 조건을 충족하는 요소만 포함하도록 결과 집합을 제한하는 작업을 나타냅니다. 지정된 조건과 일치하는 요소를 선택 한다고도 합니다.

중요합니다

이 샘플은 System.Collections.Generic.IEnumerable<T> 데이터 원본을 사용합니다. System.Linq.IQueryProvider 기반 데이터 원본은 System.Linq.IQueryable<T> 데이터 원본과 식 트리를 사용합니다. 식 트리에는 허용되는 C# 구문에 대한 제한 사항이 있습니다. 또한 IQueryProviderEF Core와 같이 더 많은 제한을 가할 수 있습니다. 데이터 원본에 대한 설명서를 확인합니다.

다음 그림에서는 문자 시퀀스를 필터링한 결과를 보여 줍니다. 필터링 작업에 대한 조건자는 문자가 'A'여야 한다고 지정합니다.

LINQ 필터링 작업을 보여 주는 다이어그램

선택을 수행하는 표준 쿼리 연산자 메서드는 다음 표에 나와 있습니다.

메서드 이름 설명 C# 쿼리 식 구문 더 많은 정보
OfType 지정된 형식으로 캐스팅할 수 있는지에 따라 값을 선택합니다. 적용할 수 없습니다. Enumerable.OfType

Queryable.OfType
어디 조건자 함수를 기반으로 하는 값을 선택합니다. where Enumerable.Where

Queryable.Where

다음 예제에서는 절을 where 사용하여 특정 길이가 있는 문자열을 배열에서 필터링합니다.

string[] words = ["the", "quick", "brown", "fox", "jumps"];

IEnumerable<string> query = from word in words
                            where word.Length == 3
                            select word;

foreach (string str in query)
{
    Console.WriteLine(str);
}

/* This code produces the following output:

    the
    fox
*/

메서드 구문을 사용하는 동일한 쿼리는 다음 코드에 나와 있습니다.

string[] words = ["the", "quick", "brown", "fox", "jumps"];

IEnumerable<string> query =
    words.Where(word => word.Length == 3);

foreach (string str in query)
{
    Console.WriteLine(str);
}

/* This code produces the following output:

    the
    fox
*/

참고하십시오