PostgreSQL에서 창 함수와 행 비교
PostgreSQL에서 창 함수는 현재 행을 인접 행과 비교하기 위한 강력한 도구를 제공합니다. 이전이든 다음이든. 인접한 행과의 비교를 기반으로 결과를 검색하려면 lag() 및 Lead()와 같은 창 함수를 효과적으로 사용할 수 있습니다.
예: 짝수 사이의 홀수 찾기
position과 random_number라는 두 개의 열이 있는 테이블을 생각해 보세요. 짝수 사이에 끼어 있는 홀수를 검색하려면 다음과 같이 창 기능을 활용할 수 있습니다.
SELECT random_number FROM ( SELECT random_number, lag(random_number, 1) OVER w AS previous_number, lead(random_number, 1) OVER w AS next_number FROM table_name WINDOW w AS (PARTITION BY position ORDER BY position) ) subquery WHERE random_number % 2 = 1 AND previous_number % 2 = 0 AND next_number % 2 = 0;
실제 사용법: 문맥 단어 식별
마찬가지로, 특정 범주(예: NAME)에 속하지 않지만 해당 범주에 속하는 단어로 둘러싸인 단어를 찾는 것이 목표인 단어 분석의 경우 동일한 접근 방식을 사용할 수 있습니다. 적용:
SELECT text FROM ( SELECT text, category, lag(category, 1) OVER w AS previous_category, lead(category, 1) OVER w AS next_category FROM token JOIN text_block_has_token ON token_id = id WINDOW w AS (PARTITION BY text_block_id, sentence ORDER BY position) ) subquery WHERE category <> 'NAME' AND previous_category = 'NAME' AND next_category = 'NAME';
창 함수의 주요 이점
창 함수를 사용하여 행을 동적으로 비교하면 여러 가지 장점이 있습니다.
위 내용은 PostgreSQL 창 함수는 어떻게 행을 비교하여 인접 데이터의 패턴을 식별할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!