구글시트 QUERY 함수 실전 예시 10개 총정리
실전예시·자주나는오류·해결방법·체크리스트
구글 시트에서 방대한 데이터를 다루다 보면, 원하는 정보만 깔끔하게 추출하고 가공하는 데 어려움을 겪는 경우가 많습니다. 수많은 행과 열 사이에서 필요한 데이터만 골라내거나, 특정 조건에 맞춰 요약하는 작업은 생각보다 많은 시간과 노력을 요구하죠.
이러한 문제에 직면했을 때, 많은 분들이 수동으로 필터를 걸거나 복잡한 함수 조합을 시도하다가 지치곤 합니다. 하지만 구글 시트의 QUERY 함수를 제대로 활용하면, 마치 데이터베이스 전문가처럼 데이터를 자유자재로 다룰 수 있게 됩니다. 복잡한 보고서를 만들거나, 특정 기준에 맞는 목록을 빠르게 뽑아내야 할 때 QUERY 함수는 그야말로 빛을 발합니다.
이 글은 구글시트 QUERY 함수실전예시 10개총정리|실전예시·자주나는오류·해결방법·체크리스트를 통해 여러분이 현업에서 마주하는 다양한 데이터 처리 문제를 해결할 수 있도록 돕습니다. QUERY 함수의 기본 개념부터 실전 예시, 그리고 자주 발생하는 오류와 해결 방법까지, 초보자도 쉽게 따라 할 수 있도록 자세히 안내해 드리겠습니다. 이 글을 통해 QUERY 함수를 마스터하고 데이터 활용 능력을 한 단계 높여보세요.
이 글을 읽으면 알 수 있는 내용:
- 구글 시트
QUERY함수의 핵심 문법과 기본 원리를 이해할 수 있습니다. - 실무에서 자주 사용되는
QUERY함수 실전 예시 10가지를 통해 다양한 데이터 처리 방법을 익힐 수 있습니다. QUERY함수 사용 시 흔히 발생하는 오류의 원인과 해결책을 파악하여 문제 해결 능력을 높일 수 있습니다.QUERY함수 적용 전 반드시 확인해야 할 체크리스트를 통해 실수를 줄이고 정확도를 높일 수 있습니다.
지금 확인해 두면 놓치기 쉬운 기준을 먼저 정리할 수 있습니다.
구글 시트 QUERY 함수 공식 도움말 확인하기QUERY 함수 핵심 개념 및 기본 문법
QUERY 함수는 구글 시트에서 데이터를 SQL(Structured Query Language)과 유사한 방식으로 조회하고 조작할 수 있게 해주는 강력한 도구입니다. 복잡한 필터링, 정렬, 그룹화, 집계 기능을 단 하나의 함수로 구현할 수 있어, 데이터 분석 및 보고서 작성 시간을 획기적으로 줄여줍니다. QUERY 함수의 기본 구조는 다음과 같습니다.
=QUERY(데이터_범위, "쿼리_문자열", [헤더_행_수])
- 데이터_범위: 쿼리를 적용할 데이터가 있는 셀 범위입니다. 예:
A1:D100 - 쿼리_문자열: SQL과 유사한 구문으로 작성된 쿼리입니다. 이 문자열은 반드시 큰따옴표(
")로 묶어야 합니다. - 헤더_행_수: (선택 사항) 데이터 범위 내에서 헤더로 인식할 행의 수입니다. 생략하거나
-1을 입력하면 구글 시트가 자동으로 판단합니다.0은 헤더가 없음을 의미합니다.
이 함수를 효과적으로 사용하려면 몇 가지 핵심 절차를 이해하는 것이 중요합니다. 아래 표는 QUERY 함수를 구성하는 주요 절차와 그 역할을 요약하여 보여줍니다.
| 핵심 절차 (Clause) | 주요 역할 | 예시 |
|---|---|---|
SELECT |
가져올 열(Column)을 지정합니다. 모든 열을 가져오려면 *를 사용합니다. SUM(), AVG() 등 집계 함수와 함께 사용됩니다. |
SELECT A, B, SUM(C) |
WHERE |
특정 조건을 만족하는 행(Row)만 필터링합니다. 논리 연산자(AND, OR, NOT)와 비교 연산자(=, <, >, <=, >=, <>)를 사용합니다. |
WHERE C > 100 AND B = '서울' |
GROUP BY |
특정 열을 기준으로 데이터를 그룹화하고, 집계 함수(SUM, AVG, COUNT, MAX, MIN)와 함께 사용합니다. |
GROUP BY A |
ORDER BY |
지정한 열을 기준으로 데이터를 오름차순(ASC) 또는 내림차순(DESC)으로 정렬합니다. 기본값은 오름차순입니다. |
ORDER BY B DESC, C ASC |
LIMIT / OFFSET |
결과 행의 개수를 제한(LIMIT)하거나, 특정 행부터 시작(OFFSET)할 때 사용합니다. 페이지네이션에 유용합니다. |
LIMIT 10 OFFSET 5 |
LABEL |
결과 열의 헤더 이름을 변경합니다. 집계 함수 결과에 특히 유용합니다. | LABEL SUM(C) '총 판매액' |
FORMAT |
결과 열의 표시 형식을 지정합니다. 날짜, 시간, 숫자 등에 적용할 수 있습니다. | FORMAT D 'yyyy-MM-dd' |
PIVOT |
지정된 열의 고유 값을 새로운 열로 변환하여 데이터를 요약합니다. 피벗 테이블과 유사한 기능을 제공합니다. | PIVOT B |
이러한 절차들을 조합하여 원하는 데이터를 정확하게 추출하고 가공할 수 있습니다. 이제 실제 데이터 시나리오에 적용되는 10가지 실전 예시를 통해 QUERY 함수의 강력함을 직접 경험해 보세요.
구글 시트 QUERY 함수 실전 예시 10가지
다음은 실제 업무에서 자주 활용될 수 있는 QUERY 함수 실전 예시 10가지입니다. 각 예시마다 설명, 함수, 그리고 결과에 대한 간략한 해설을 포함하고 있습니다. 예시 데이터는 A열부터 D열까지 다음과 같다고 가정합니다: A(제품명), B(카테고리), C(판매량), D(판매일).
1. 특정 열만 선택하기 (SELECT)
가장 기본적인 사용법으로, 전체 데이터에서 필요한 열만 추출할 때 사용합니다.
=QUERY(A1:D100, "SELECT A, C")
설명: A1부터 D100 범위에서 A열(제품명)과 C열(판매량)만 가져옵니다.
2. 특정 조건으로 필터링하기 (WHERE)
특정 조건을 만족하는 행만 필터링하여 보여줍니다. 예를 들어, 판매량이 50 이상인 제품만 보고 싶을 때 유용합니다.
=QUERY(A1:D100, "SELECT A, B, C WHERE C >= 50")
설명: A1부터 D100 범위에서 C열(판매량)이 50 이상인 모든 행의 A, B, C열을 선택합니다.
3. 여러 조건으로 필터링하기 (WHERE AND/OR)
AND 또는 OR 연산자를 사용하여 여러 조건을 동시에 적용할 수 있습니다. 예를 들어, '전자제품' 카테고리이면서 판매량이 100 이상인 제품을 찾을 때 사용합니다.
=QUERY(A1:D100, "SELECT A, B, C WHERE B = '전자제품' AND C >= 100")
설명: B열이 '전자제품'이고 C열이 100 이상인 행의 A, B, C열을 선택합니다.
4. 데이터 정렬하기 (ORDER BY)
특정 열을 기준으로 데이터를 오름차순(ASC) 또는 내림차순(DESC)으로 정렬합니다. 판매량이 높은 순서대로 제품을 나열할 때 유용합니다.
=QUERY(A1:D100, "SELECT A, B, C ORDER BY C DESC")
설명: A, B, C열을 선택하고, C열(판매량)을 기준으로 내림차순으로 정렬합니다.
5. 데이터 그룹화 및 집계하기 (GROUP BY, SUM, AVG)
특정 열을 기준으로 데이터를 그룹화하고, 각 그룹별로 판매량 합계, 평균 등을 계산할 수 있습니다. 카테고리별 총 판매량을 집계할 때 사용합니다.
=QUERY(A1:D100, "SELECT B, SUM(C) GROUP BY B")
설명: B열(카테고리)을 기준으로 그룹화하고, 각 카테고리별 C열(판매량)의 합계를 계산합니다.
6. 특정 개수만큼 가져오기 (LIMIT, OFFSET)
결과 데이터의 행 수를 제한하거나, 특정 시작점부터 데이터를 가져올 수 있습니다. 상위 N개 또는 특정 페이지의 데이터를 가져올 때 유용합니다.
=QUERY(A1:D100, "SELECT A, C ORDER BY C DESC LIMIT 5")
설명: 판매량을 기준으로 내림차순 정렬한 후, 상위 5개 제품의 A, C열만 가져옵니다.
7. 날짜 기준으로 필터링하기 (WHERE Date)
특정 날짜 범위 내의 데이터를 필터링할 수 있습니다. 날짜는 DATE 'YYYY-MM-DD' 형식으로 지정해야 합니다.
=QUERY(A1:D100, "SELECT A, D WHERE D >= DATE '2023-01-01' AND D <= DATE '2023-01-31'")
설명: 2023년 1월 한 달 동안의 판매 데이터 중 A, D열을 가져옵니다.
8. 텍스트 포함 여부로 필터링하기 (WHERE CONTAINS)
특정 열에 특정 텍스트가 포함되어 있는지 여부로 필터링할 수 있습니다. 제품명에 '프리미엄'이 들어간 제품을 찾을 때 유용합니다.
=QUERY(A1:D100, "SELECT A, B WHERE A CONTAINS '프리미엄'")
설명: A열(제품명)에 '프리미엄'이라는 단어가 포함된 모든 행의 A, B열을 선택합니다.
9. 피벗 테이블처럼 데이터 요약하기 (PIVOT)
PIVOT 절을 사용하여 특정 열의 고유 값을 새로운 열로 변환하고 데이터를 요약할 수 있습니다. 예를 들어, 각 카테고리별 제품의 판매량을 피벗 형태로 보고 싶을 때 사용합니다.
=QUERY(A1:D100, "SELECT A, SUM(C) GROUP BY A PIVOT B")
설명: A열(제품명)을 기준으로 C열(판매량)을 합산하고, B열(카테고리)의 고유 값을 새로운 열로 만들어 각 제품의 카테고리별 판매량을 보여줍니다.
예시 데이터와 결과 (가정):
| 제품명 (A) | 카테고리 (B) | 판매량 (C) |
|---|---|---|
| 노트북 | 전자제품 | 100 |
| 키보드 | 전자제품 | 50 |
| 책상 | 가구 | 30 |
| 의자 | 가구 | 40 |
| 노트북 | 전자제품 | 120 |
위 쿼리 적용 시 예상 결과:
| 제품명 | 전자제품 | 가구 |
|---|---|---|
| 노트북 | 220 | |
| 키보드 | 50 | |
| 책상 | 30 | |
| 의자 | 40 |
10. 여러 집계 함수와 레이블 사용하기 (LABEL)
여러 집계 함수를 동시에 사용하고, 결과 열의 헤더 이름을 사용자 정의할 수 있습니다. 카테고리별 총 판매량과 평균 판매량을 함께 보고 헤더를 명확하게 지정할 때 사용합니다.
=QUERY(A1:D100, "SELECT B, SUM(C), AVG(C) GROUP BY B LABEL SUM(C) '총 판매량', AVG(C) '평균 판매량'")
설명: B열(카테고리)을 기준으로 그룹화하여 C열(판매량)의 합계와 평균을 계산하고, 각 집계 결과의 헤더를 '총 판매량'과 '평균 판매량'으로 변경합니다.
자주 발생하는 QUERY 함수 오류 및 해결 방법
QUERY 함수는 강력하지만, 복잡한 구문 때문에 오류가 발생하기 쉽습니다. 다음은 자주 발생하는 오류 유형과 그 해결 방법입니다.
| 오류 유형 | 주요 원인 | 해결 방법 |
|---|---|---|
#VALUE! 또는 Query completed with no results. |
|
|
Formula parse error. |
|
|
| 날짜/시간 필터링 문제 |
|
|
| 헤더 행 처리 문제 |
|
|
QUERY 함수 적용 전 체크리스트
QUERY 함수를 사용하기 전에 다음 체크리스트를 확인하면 오류를 줄이고 효율적으로 작업할 수 있습니다.
1. 데이터 범위 확인: 쿼리를 적용할 데이터 범위(예: A1:D100)가 정확한지, 불필요한 행이나 열이 포함되지 않았는지 확인합니다.
2. 컬럼 참조 방식 이해: QUERY 함수는 데이터 범위 내의 컬럼을 A, B, C... 또는 Col1, Col2, Col3... 형태로 참조할 수 있습니다. 일반적으로 시트의 컬럼명과 동일하게 A, B, C를 사용하지만, IMPORTRANGE 등으로 가져온 데이터는 Col1, Col2를 사용해야 할 수 있습니다.
3. 데이터 타입 일관성: 각 컬럼의 데이터 타입(숫자, 문자열, 날짜)이 일관적인지 확인합니다. 한 컬럼에 숫자와 문자열이 혼재되어 있으면 QUERY 함수가 해당 컬럼을 문자열로 인식하여 예상치 못한 결과를 줄 수 있습니다.
4. 따옴표 사용 규칙:
- 쿼리 문자열 전체는 큰따옴표(
")로 묶습니다. - 쿼리 문자열 내에서 문자열 리터럴(예: 텍스트 값)은 작은따옴표(
')로 묶습니다. - 날짜는
DATE 'YYYY-MM-DD', 시간은DATETIME 'YYYY-MM-DD HH:MM:SS'형식으로 지정합니다.
5. 헤더 행 지정: QUERY 함수의 세 번째 인자인 헤더 행 수를 정확히 지정하여, 데이터의 첫 행이 헤더인지 데이터인지 명확히 알려줍니다.
6. 대소문자 구분: QUERY 함수는 기본적으로 대소문자를 구분합니다. 텍스트 필터링 시 이 점을 유의해야 합니다 (예: '전자제품'과 '전자제품'은 다르게 인식될 수 있음).
QUERY 함수 실전 활용 팁
더욱 효율적인 QUERY 함수 사용을 위한 추가 팁입니다.
| 팁 | 설명 | 예시 |
|---|---|---|
| 복잡한 쿼리 분리 | 쿼리가 너무 길고 복잡해지면, 여러 개의 QUERY 함수를 중첩하거나, 중간 결과를 다른 시트에 저장하여 단계별로 처리하면 디버깅이 용이합니다. |
=QUERY(QUERY(A:D, "SELECT A, B WHERE C > 100"), "SELECT Col1, Col2 ORDER BY Col1") |
| 셀 참조 활용 | 쿼리 문자열 내에 특정 셀의 값을 동적으로 포함시켜, 조건을 유연하게 변경할 수 있습니다. & 연산자를 사용하여 셀 값을 연결합니다. |
=QUERY(A:D, "SELECT A, B WHERE C > " & E1 & "") (E1 셀에 숫자 조건 입력) |
| 임시 데이터 시트 활용 | 원본 데이터가 너무 커서 테스트가 어렵거나, 여러 쿼리에서 동일한 서브셋을 사용해야 할 경우, 임시 시트에 필요한 데이터만 복사하여 테스트하거나 활용합니다. | (설명으로 대체) |
| 오류 메시지 활용 | QUERY 함수는 오류 발생 시 비교적 상세한 메시지를 제공합니다. 이 메시지를 주의 깊게 읽으면 문제 해결에 큰 도움이 됩니다. |
(설명으로 대체) |
결론: QUERY 함수 마스터로 데이터 활용 능력 향상
구글 시트의 QUERY 함수는 단순한 데이터 필터링을 넘어, 복잡한 데이터 분석과 보고서 작성을 자동화할 수 있는 강력한 도구입니다. 이 글에서 다룬 10가지 실전 예시와 자주 발생하는 오류 해결 방법, 그리고 체크리스트를 통해 여러분은 QUERY 함수를 더욱 효과적으로 활용할 수 있게 될 것입니다.
처음에는 다소 어렵게 느껴질 수 있지만, 꾸준히 연습하고 다양한 시나리오에 적용해 보면서 QUERY 함수의 진정한 가치를 발견하게 될 것입니다. 데이터 처리 시간을 획기적으로 줄이고, 더 정확하고 통찰력 있는 보고서를 작성하는 데 QUERY 함수가 큰 도움이 되기를 바랍니다. 지금 바로 여러분의 구글 시트에서 QUERY 함수를 활용하여 데이터 마스터로 거듭나세요!
0 댓글