> 백엔드 개발 > C++ > 일반 열 이름으로 IQueryable의 OrderBy를 어떻게 확장할 수 있나요?

일반 열 이름으로 IQueryable의 OrderBy를 어떻게 확장할 수 있나요?

Linda Hamilton
풀어 주다: 2025-01-14 09:40:44
원래의
684명이 탐색했습니다.

How Can I Extend IQueryable's OrderBy with Generic Column Names?

일반 열 이름으로 IQueryable의 OrderBy 메서드 확장

이 기사에서는 주어진 문자열 열 이름을 기준으로 정렬할 수 있도록 일반 확장 메서드로 IQueryable을 향상시키는 방법을 살펴봅니다.

다음 확장 방법을 고려하세요.

<code class="language-csharp">public static IQueryable<TResult> ApplySortFilter<T, TResult>(this IQueryable<T> query, string columnName)
    where T : EntityObject</code>
로그인 후 복사

정렬 기능을 구현하려면 주어진 컬럼 이름을 사용하여 표현식을 작성해야 합니다. 그러나 문제가 발생했습니다. 표현식에서 유추된 순서 유형이 OrderBy 메서드에 필요한 유형과 일치하지 않았습니다.

정렬 유형 TSortColumn은 런타임에만 결정될 수 있으므로 이는 문제가 됩니다. 그러나 해결책이 있습니다.

제공된 코드 예제는 유사한 접근 방식을 보여줍니다.

<code class="language-csharp">public static IQueryable<T> OrderBy<T>(this IQueryable<T> source, string ordering, params object[] values)</code>
로그인 후 복사

이 메소드는 열 이름을 나타내는 문자열 매개변수 ordering를 허용합니다. 지정된 열 이름과 람다 표현식을 기반으로 표현식을 동적으로 생성합니다. 그런 다음 결과 표현식을 사용하여 OrderBy 메서드를 호출하는 MethodCallExpression을 만듭니다.

마지막으로 source.Provider.CreateQuery<T>이 호출되어 정렬된 IQueryable을 반환합니다.

수정: 내림차순 정렬:

<code class="language-csharp">MethodCallExpression resultExp = Expression.Call(typeof(Queryable), "OrderByDescending", new Type[] { type, property.PropertyType }, source.Expression, Expression.Quote(orderByExp));</code>
로그인 후 복사

위 내용은 일반 열 이름으로 IQueryable의 OrderBy를 어떻게 확장할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿