> 데이터 베이스 > MySQL 튜토리얼 > BigQuery에서 행을 열로 바꾸는 방법은 무엇입니까?

BigQuery에서 행을 열로 바꾸는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2025-01-05 18:33:43
원래의
483명이 탐색했습니다.

How to Transpose Rows into Columns in BigQuery?

BigQuery에서 행을 열로 전치: 피벗 구현

행을 열로 전치(피버팅이라고도 함)하면 키-값 쌍을 새 테이블로 변환할 수 있습니다. 여기서 키는 열 이름이 되고 값은 해당 셀에 배치됩니다. BigQuery는 기본적으로 피벗 기능을 지원하지 않지만 간단한 접근 방식을 사용하여 이를 달성할 수 있습니다.

입력 테이블 구조

시작하려면 입력 테이블에 다음 열이 있는지 확인하세요.

  • Key : 각각의 카테고리를 지정하는 컬럼 row.
  • Value: 키에 해당하는 값.

추가로, 단일로 결합해야 하는 행을 그룹화하는 열이 필요합니다.

1단계: 입력 데이터를 전치된 쿼리 문자열로 변환

In 1단계에서는 실행 시 전치된 쿼리를 생성하는 쿼리 문자열을 만듭니다. 다음 쿼리를 실행합니다.

SELECT 'SELECT id, ' + 
   GROUP_CONCAT_UNQUOTED(
      'MAX(IF(key = "' + key + '", value, NULL)) as [' + key + ']'
   ) 
   + ' FROM yourTable GROUP BY id ORDER BY id'
FROM (
  SELECT key 
  FROM yourTable
  GROUP BY key
  ORDER BY key
) 
로그인 후 복사

2단계: 전치 쿼리 실행

1단계의 결과를 복사하여 일반 쿼리로 실행합니다. 이렇게 하면 전치된 데이터가 포함된 테이블이 생성됩니다.

SELECT 
  id, 
  MAX(IF(key = "channel_id", value, NULL)) AS [channel_id],
  MAX(IF(key = "channel_title", value, NULL)) AS [channel_title],
  MAX(IF(key = "examId", value, NULL)) AS [examId],
  MAX(IF(key = "postId", value, NULL)) AS [postId],
  MAX(IF(key = "youtube_id", value, NULL)) AS [youtube_id] 
FROM yourTable 
GROUP BY id 
ORDER BY id
로그인 후 복사

결과 테이블의 구조는 다음과 같습니다.

id channel_id channel_title examId postId youtube_id
1 UCiDKcjKocimAO1tV Mahendra Guru 72975611-4a5e-11e5 1189e340-b08f ugEGMG4-MdA
2 UCODeKM_D6JLf8jJt Ab Live 72975611-4a5e-11e5 0c3e6590-afeb 3TNbtTwLY0U

참고

테이블 크기가 큰 경우 열 수가 많으면 전치된 쿼리를 수동으로 구성하여 1단계를 건너뛸 수 있습니다. 그러나 1단계에서는 쿼리를 동적으로 생성하는 빠르고 편리한 방법을 제공합니다.

위 내용은 BigQuery에서 행을 열로 바꾸는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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