📊 SQL로 데이터를 정렬하고 직업별 사람 수 구하기! 🎓

✨ 소개

SQL을 사용하면 데이터를 정리하고 분석하는 데 정말 유용한 도구입니다! 오늘은 이름을 알파벳 순으로 정렬하고 직업별로 몇 명이 있는지 계산하는 방법을 배워볼 거예요. 이 방법을 활용하면 테이블에 저장된 데이터를 좀 더 쉽게 이해할 수 있답니다.

여러분이 SQL 초보라면, 너무 어렵게 생각하지 마세요. 천천히 따라오시면 중학생도 충분히 이해할 수 있을 거예요! 😊

 

🎯 문제 설명

우리는 OCCUPATIONS라는 테이블을 사용해요. 이 테이블에는 각 사람의 이름과 그 사람이 가진 직업 정보가 담겨 있어요. 우리는 이 테이블을 이용해 두 가지 작업을 할 거예요:

  1. 이름을 알파벳 순으로 정렬하고 그 뒤에 직업의 첫 글자를 괄호로 묶어서 보여주기.
  2. 각 직업별로 몇 명이 있는지 계산하고, 그 수를 오름차순으로 정렬해서 보여주기.

💡 해결 방법

1️⃣ 첫 번째 작업: 이름과 직업 첫 글자 출력하기

첫 번째 작업에서는 이름을 알파벳 순으로 정렬하고, 그 뒤에 직업의 첫 글자를 괄호로 묶어서 표시해요. 예를 들어, Amy(A), Bob(D) 이런 식으로 나와야 해요.

 

SQL 쿼리는 이렇게 작성할 수 있습니다:

SELECT 
    CONCAT(Name, '(', SUBSTRING(Occupation, 1, 1), ')') AS result
FROM 
    OCCUPATIONS;

 

  • CONCAT(): 문자열을 이어 붙일 때 사용해요. 여기서는 이름과 괄호 안의 직업 첫 글자를 합쳤어요.
  • SUBSTRING(): 직업 이름의 첫 번째 글자만 가져오는 함수예요.

2️⃣ 두 번째 작업: 직업별 사람 수 계산하기

두 번째 작업에서는 각 직업에 몇 명이 있는지 계산해요. 예를 들어, There are a total of 3 doctors. 이렇게 출력되도록 해야 해요.

SQL 쿼리는 이렇게 작성할 수 있습니다:

 

SELECT 
    CONCAT('There are a total of ', COUNT(*), ' ', LOWER(Occupation), 's.') AS result
FROM 
    OCCUPATIONS
GROUP BY 
    Occupation
ORDER BY 
    COUNT(*), Occupation;

 

 

  • COUNT(*): 직업별로 몇 명이 있는지 계산해요.
  • LOWER(): 직업 이름을 소문자로 바꿔주는 함수예요.
  • GROUP BY: 직업별로 그룹을 나누고 각 직업마다 몇 명이 있는지 세요.
  • ORDER BY: 인원 수를 기준으로 오름차순 정렬하고, 인원이 같은 경우 직업명을 알파벳 순으로 정렬해요.

🎉 두 작업을 한 번에 합치기

이제 두 쿼리를 하나의 쿼리로 합쳐서, 한 번에 결과를 볼 수 있게 할 거예요! UNION ALL을 사용하면 두 개의 결과를 하나로 합칠 수 있어요.

 

(SELECT 
    CONCAT(Name, '(', SUBSTRING(Occupation, 1, 1), ')') AS result
 FROM 
    OCCUPATIONS)

UNION ALL

(SELECT 
    CONCAT('There are a total of ', COUNT(*), ' ', LOWER(Occupation), 's.') AS result
 FROM 
    OCCUPATIONS
 GROUP BY 
    Occupation)

ORDER BY 
    result;

 

 

  • UNION ALL: 두 개의 쿼리 결과를 하나로 합쳐줘요.
  • 마지막에 **ORDER BY**를 한 번만 사용해서, 전체 결과를 알파벳 순으로 정렬해요.

🔍 결과 예시

이 쿼리를 실행하면 아래와 같은 결과를 얻을 수 있어요:

 

Alice(A)
Bob(D)
There are a total of 3 doctors.
There are a total of 5 singers.

 

이렇게 SQL을 사용해서 데이터를 정리하면, 복잡한 데이터를 쉽게 볼 수 있어요!

💭 결론

오늘은 SQL을 이용해 이름을 정렬하고 직업별 인원을 계산하는 방법을 배웠어요. 이제 SQL로 여러분의 데이터를 더 쉽게 관리할 수 있을 거예요. 다음에도 유익한 SQL 팁을 공유할 테니, 기대해 주세요! 😄

SQL을 배우는 즐거움을 느끼고 있다면, 댓글로 여러분의 경험을 공유해 주세요! 감사합니다

'SQL' 카테고리의 다른 글

Japan Population  (0) 2024.10.07
Revising Aggregations - Averages  (1) 2024.10.06
Revising Aggregations - The Sum Function  (0) 2024.10.03
Type of Triangle  (1) 2024.10.02
Employee Salaries  (0) 2024.09.30

SQL로 특정 지역의 총 인구 구하기: District가 'California'인 도시들의 인구수 합산

SQL은 데이터베이스에서 데이터를 효율적으로 추출하고 분석할 수 있는 매우 강력한 도구입니다. 이번 포스팅에서는 SQL을 사용하여 특정 지역, 즉 'California' 지역에 속한 도시들의 총 인구를 구하는 방법을 알아보겠습니다.

테이블 구조

아래는 이번 예시에서 사용할 테이블 CITY의 구조입니다. CITY 테이블은 도시 정보를 담고 있으며, 각 필드는 도시의 다양한 속성을 나타냅니다.

FieldType

ID NUMBER
NAME VARCHAR2(17)
COUNTRYCODE VARCHAR2(3)
DISTRICT VARCHAR2(20)
POPULATION NUMBER

문제: District가 'California'인 도시들의 총 인구 구하기

이 테이블에서 우리는 'California' 지역에 속한 도시들의 인구수 합계를 구하고자 합니다. 이를 해결하기 위해서는 SUM 함수를 사용하여 해당 지역의 도시들의 인구수를 모두 더해줘야 합니다.

 

SQL 쿼리

SELECT SUM(POPULATION)
FROM CITY
WHERE DISTRICT = 'California';

 

쿼리 설명:

  • SELECT SUM(POPULATION): POPULATION 컬럼에서 값들을 더합니다. 즉, 도시들의 인구수를 합산합니다.
  • FROM CITY: CITY 테이블에서 데이터를 가져옵니다.
  • WHERE DISTRICT = 'California': DISTRICT 값이 'California'인 도시들만 필터링합니다.

이 쿼리는 'California' 지역에 속한 도시들의 총 인구를 반환합니다.

결론

SQL에서 특정 조건을 만족하는 데이터의 총합을 구하는 것은 매우 흔하게 사용되는 작업입니다. 특히 인구수나 매출과 같은 수치 데이터를 다룰 때 유용합니다. 이번 포스팅에서 다룬 예시처럼 SUM 함수와 WHERE 절을 적절히 활용하면 원하는 데이터를 손쉽게 추출할 수 있습니다. 이제 여러분도 직접 데이터베이스에서 필요한 데이터를 SQL로 쉽게 추출해보세요!

'SQL' 카테고리의 다른 글

Revising Aggregations - Averages  (1) 2024.10.06
The PADS  (1) 2024.10.06
Type of Triangle  (1) 2024.10.02
Employee Salaries  (0) 2024.09.30
Employee Names  (1) 2024.09.28

SQL로 삼각형 유형 분류하기

서론

 데이터베이스에서 삼각형의 세 변(A, B, C)의 길이를 기준으로 삼각형의 유형을 분류하는 방법을 소개합니다. 이 포스팅에서는 주어진 세 변을 사용해 삼각형의 유형을 SQL 쿼리를 통해 간단하고 효율적으로 분류하는 방법을 설명합니다. 그 과정에서 삼각형의 수학적 성질을 활용하여 정삼각형, 이등변삼각형, 부등변삼각형 그리고 삼각형이 아닌 경우를 식별할 수 있습니다.

 

문제 정의

우리는 TRIANGLES라는 테이블을 다루게 됩니다. 이 테이블은 각 삼각형을 나타내는 세 개의 열(A, B, C)로 이루어져 있으며, 이들은 각각 삼각형의 변의 길이를 나타냅니다. 목표는 각 레코드의 세 변을 사용하여 다음과 같은 네 가지 분류 중 하나로 출력하는 것입니다:

  1. Equilateral (정삼각형): 세 변의 길이가 모두 동일한 삼각형
  2. Isosceles (이등변삼각형): 두 변의 길이가 동일한 삼각형
  3. Scalene (부등변삼각형): 세 변의 길이가 모두 다른 삼각형
  4. Not A Triangle (삼각형이 아님): 주어진 변의 길이로는 삼각형을 만들 수 없음

삼각형의 조건

삼각형을 이루기 위해서는 세 변의 길이가 다음 조건을 만족해야 합니다:

  • A + B > C
  • A + C > B
  • B + C > A

만약 이 조건을 만족하지 못하면, 해당 세 변으로는 삼각형을 만들 수 없습니다.

 

SQL 쿼리 작성

 

SELECT CASE
    WHEN A + B <= C OR A + C <= B OR B + C <= A THEN 'Not A Triangle'
    WHEN A = B AND B = C THEN 'Equilateral'
    WHEN A = B OR A = C OR B = C THEN 'Isosceles'
    ELSE 'Scalene'
END AS Triangle_Type
FROM TRIANGLES;

 

쿼리 설명:

  1. 삼각형이 아닌 경우: A + B <= C 또는 A + C <= B 또는 B + C <= A인 경우, 주어진 세 변은 삼각형을 만들 수 없습니다. 이 경우, 결과는 'Not A Triangle'이 됩니다.
  2. 정삼각형 (Equilateral): 세 변의 길이(A, B, C)가 모두 동일한 경우, 결과는 'Equilateral'이 됩니다.
  3. 이등변삼각형 (Isosceles): 세 변 중 두 변의 길이(A, B, C)가 동일한 경우, 결과는 'Isosceles'로 분류됩니다.
  4. 부등변삼각형 (Scalene): 세 변의 길이가 모두 다른 경우, 결과는 'Scalene'으로 출력됩니다.

쿼리 실행 결과

위의 쿼리를 실행하면 각 레코드의 세 변의 길이에 따라 'Equilateral', 'Isosceles', 'Scalene', 또는 'Not A Triangle'이라는 결과를 얻을 수 있습니다.

결론

이번 포스팅에서는 삼각형의 유형을 SQL을 통해 간단하게 분류하는 방법을 다뤄봤습니다. SQL의 CASE 문을 활용하면 다양한 조건에 따라 데이터를 쉽게 분류할 수 있으며, 이를 통해 보다 효율적인 데이터 처리와 분석이 가능합니다. 다음에는 더 복잡한 분류 문제나 데이터 분석 문제를 다뤄보겠습니다!

'SQL' 카테고리의 다른 글

The PADS  (1) 2024.10.06
Revising Aggregations - The Sum Function  (0) 2024.10.03
Employee Salaries  (0) 2024.09.30
Employee Names  (1) 2024.09.28
Higher Than 75 Marks  (0) 2024.09.26

SQL 쿼리 분석: 짧은 근무 기간에도 높은 급여를 받는 직원 찾기

데이터 분석에서 SQL은 매우 강력한 도구입니다. 오늘은 특정 조건을 만족하는 직원들의 정보를 추출하는 간단한 SQL 쿼리를 함께 살펴보겠습니다. 이번 포스팅의 목표는 월급이 $2000 이상이면서 10개월 미만 근무한 직원들의 이름을 찾아내는 것입니다.

 

테이블 구조

먼저, 직원 정보를 담고 있는 Employee 테이블의 구조부터 확인해 보겠습니다. 아래 표는 Employee 테이블의 각 컬럼과 데이터 유형을 보여줍니다:

ColumnType

employee_id Integer
name String
months Integer
salary Integer

 

SQL 쿼리

SELECT name
FROM Employee
WHERE salary > 2000 AND months < 10
ORDER BY employee_id ASC;

 

쿼리 설명

이 쿼리는 다음과 같은 조건을 기반으로 데이터를 검색합니다:

  • 월급 조건: salary 컬럼이 2000을 초과해야 합니다.
  • 근무 기간 조건: months 컬럼이 10 미만이어야 합니다.

조건을 만족하는 직원들의 name을 선택하고, employee_id를 기준으로 오름차순으로 결과를 정렬합니다.

결과

이 쿼리를 실행하면, 월급이 상대적으로 높으면서도 근무 기간이 짧은 직원들의 이름이 출력됩니다. 이러한 정보는 인사 팀이나 경영진이 보상 구조를 평가하거나 직원의 경력 개발을 지원하는 데 유용할 수 있습니다. 감사합니다.

'SQL' 카테고리의 다른 글

Revising Aggregations - The Sum Function  (0) 2024.10.03
Type of Triangle  (1) 2024.10.02
Employee Names  (1) 2024.09.28
Higher Than 75 Marks  (0) 2024.09.26
Weather Observation Station 12  (2) 2024.09.24

SQL 쿼리로 직원 이름 알파벳 순 출력하기

데이터베이스 관리의 필수적인 스킬 중 하나가 바로 SQL 쿼리입니다. 이번 포스팅에서는 기업의 직원 목록을 알파벳 순으로 정렬

테이블 구조

아래 표는 Employee 테이블의 구조를 나타냅니다. 이 테이블에는 직원의 ID, 이름, 근무 개월 수, 월급 정보가 저장되어 있습니다.

ColumnType

employee_id Integer
name String
months Integer
salary Integer

하는 간단한 SQL 쿼리를 작성하는 방법을 소개하고자 합니다.

 

SQL 쿼리 작성

SELECT name
FROM Employee
ORDER BY name ASC;

 

 

쿼리 설명

  • SELECT name: Employee 테이블에서 name 열만을 선택합니다.
  • ORDER BY name ASC: 선택된 이름을 알파벳 오름차순으로 정렬합니다.

이 쿼리는 데이터베이스에서 직원의 이름을 간단하게 조회하고 정렬하는 데 사용됩니다. 데이터 정리나 보고서 작성 시 유용하게 활용될 수 있습니다.


이 포스팅이 SQL 쿼리의 기초를 이해하는 데 도움이 되었길 바라며, 간단한 쿼리임에도 불구하고 실제 업무에서 중요한 역할을 할 수 있습니다. 데이터베이스 관리에 관심이 있는 분들을 위해, 다음 포스팅에서는 보다 복잡한 쿼리 작성법을 다루도록 하겠습니다. 계속해서 관심을 가져주세요!

'SQL' 카테고리의 다른 글

Type of Triangle  (1) 2024.10.02
Employee Salaries  (0) 2024.09.30
Higher Than 75 Marks  (0) 2024.09.26
Weather Observation Station 12  (2) 2024.09.24
Weather Observation Station 11  (0) 2024.09.23

SQL 쿼리 작성: 점수 기준 학생 이름 조회 및 정렬

문제 설명

우리는 학교 데이터베이스의 STUDENTS 테이블을 사용하여 75점 이상의 점수를 받은 학생들의 이름을 조회하고 싶습니다. 또한, 조회된 결과를 각 이름의 마지막 세 글자를 기준으로 정렬하며, 같은 세 글자로 끝나는 이름이 여러 개 있을 경우에는 학생의 ID 순으로 오름차순 정렬하려고 합니다.

테이블 구조

STUDENTS 테이블은 다음과 같은 구조를 가지고 있습니다:

ColumnType

ID Integer
Name String
Marks Integer

 

SQL 쿼리

SELECT Name
FROM STUDENTS
WHERE Marks > 75
ORDER BY RIGHT(Name, 3), ID;

 

쿼리 설명

  1. SELECT 문: Name 열에서 데이터를 선택합니다. 이는 출력될 데이터가 학생들의 이름임을 의미합니다.
  2. FROM 절: STUDENTS 테이블에서 데이터를 가져옵니다.
  3. WHERE 절: Marks 열의 값이 75를 초과하는 행만 필터링합니다. 이 조건은 우리가 관심 있는 학생들, 즉 75점 이상을 받은 학생들만을 대상으로 합니다.
  4. ORDER BY 절: 먼저 RIGHT(Name, 3) 함수를 사용하여 각 이름의 마지막 세 글자를 기준으로 결과를 정렬합니다. 동일한 세 글자로 끝나는 이름이 여러 개인 경우, ID 열을 기준으로 추가적인 오름차순 정렬을 수행하여 결과의 순서를 결정합니다.

결론

이 SQL 쿼리는 데이터베이스에서 특정 조건에 맞는 데이터를 효율적으로 필터링하고 정렬하는 간단하지만 강력한 예제를 보여줍니다. 특히, RIGHT() 함수와 같은 문자열 함수를 사용하여 복잡한 정렬 조건을 쉽게 처리할 수 있음을 보여줍니다. 이러한 기술은 다양한 데이터 처리 상황에서 유용하게 사용될 수 있습니다.

'SQL' 카테고리의 다른 글

Employee Salaries  (0) 2024.09.30
Employee Names  (1) 2024.09.28
Weather Observation Station 12  (2) 2024.09.24
Weather Observation Station 11  (0) 2024.09.23
Weather Observation Station 10  (2) 2024.09.22

도수분포표와 히스토그램: 데이터의 특징을 돋보이게 하는 도구

  • 데이터 자체(단순한 숫자의 나열)을 뚫어져라 처다본다고 해서 어떤 정보를 속시원하게 알수가 없다.
  • ex) 80명의 키를 정리한 데이터를 보고 어떠한 정보를 살펴볼수 있는지 알아보자
    • 데이터를 본다면 모두 같지 않고 제각각의 수치로 나타난다는 점을 알수 있다.
    • 이렇게 데이터가 다양한 수치로 나타나는 것을 전문적인 용어로 분포한다(discribute)라고 표현한다.

 

학생 80명의 키(cm)

151   154   160   160   163   156   158   156   154   160
154   162   156   162   157   162   162   169   150   162
154   152   161   160   160   153   155   163   160   159
164   158   150   155   157   161   168   162   153   154
158   151   155   155   165   165   154   148   169   158
146   166   161   143   156   156   149   162   159   164
162   167   159   153   146   156   160   151   151   157
151   156   166   159   157   156   159   156   156   161

 

  • 분포가 생기는 이유
    • 수치들이 결정된 이면에 어떤 불확실성(uncertainty)이 움직이고 있기 때문이다.
    • 불확실성의 구조가 제각각인 키의 수치를 발생시킨다고 생각하는 것이다.
    • 불확실이라는 말로 표현 해도 여기에는 고유한 특징이나 반복되는 것이 있는데 이를 분포의 특성이라고 한다.
    • 분포의 특성과 반복되는것을 이끌어 내기 위한 것이 통계이다.
  • 통계에서 사용되는 방법 '축약'
    • 데이터로 나열되어 있는 많은 숫자를 어떤 기준으로 정리정돈해서 의미 있는 정보만을 추출하는 것으로 2가지 방법을 사용한다.
      1. 그래프로 만들어서 그 특징을 파악할 수 있도록 해야한다.
      2. 숫자 하나로 특징을 대표하도록 한다.
    • 축약을 대표하는 숫자를 통계량이라고 한다.

히스토그램(막대그래프) 만들기

  • 히스토그램을 만들기 위해서는 도수분표표를 만들어야 한다.

도수분표표 만들기

  1. 데이터 중에서 수치가 가장 큰 것(최대값)과 가장 작은 것 (최소값)을 찾는다.
  2. 최대값부터 최소값까지 포함되도록 하여 구간을 자르기 좋은 범위(작은 구간)들로 자른다. 이렇게 작은 범위를
    '계급'(class)라고 한다.
  3. 계급을 대표하는 수치를 정한다. 기본적으로 아무 값이나 대표로 정해도 되지만, 일반적으로 가장 가운데 값을 선택하는 경우가 많다. 이값을 '계급값'(class value)라고 한다.
  4. 각 계급에 들어가 있는 데이터의 총 개수를 센다 이것을 '도수(frequency)'라고 한다.
  5. 각 계급의 도수가 전체에서 차지하는 비율을 계산한다. 이것을 상대도수(relative frequency)라고 한다. 상대도수는 합하면 1이 된다.
  6. 어느 계급까지의 도수를 모두 합한다. 이것을 누적도수(cumulative frequency)라고 한다. 최종 누적도수는 데이터의 전체 개수와 같다.\
계급 계급값 도수 상대도수 누적도수
141 ~ 145 143 1 0.0125 1
146 ~ 150 148 6 0.0750 7
151 ~ 155 153 19 0.2375 26
156 ~ 160 158 30 0.3750 56
161 ~ 165 163 18 0.2250 74
166 ~ 170 168 6 0.0750 80

 

도수분포표의 특징

  • 도수분표표를 만들면 잃어버리는 정보가 있다.
    • 데이터에 나타나 있던 수치들 자체이다.
    • 예를 들어 제 4계급인 150 ~ 160가지의 범위를 보면 30개의 데이터가 있다는걸 알 수 있지만 세부적인 수치는 알수가 없다. 
      • 도수분표표를 만드는 과정에서 축약을 하는 과정으로 인해 발생한 일이다.
  • 도수분표표를 통해 얻을 수 있는 정보가 있다.
    • 도수를 통해 다음과 같은 데이터의 특징을 발견할 수 있다.
      • 데이터는 균등하게 분포하지 않고 어느 한 곳에 (156 ~ 160) 계급에 집중되어 있다.
      • 집중되어 있는 곳을 기점으로 삼으면 작은편에 속하는지 큰편에 속하는지 추이를 알 수 있다. 즉 데이터 분포에 어느 한곳을 축으로 좌우 대칭성이 있다는 것이다.
    • 여성들의 키가 정해지게 된 구조 뒤에는 어떠한 불확실성이 있지만 여기에는 고유한 특징이 있다.
      1. 어떠한 수치든지 가능한 것은 아니다.
      2. 어느 한 키(158cm) 주변에 집중되어 있다.
      3. 158cm 기점으로 해서 큰편과 작은 편은 '수치가 별로 보이지 않는다는점이 서로 비슷하다.
    • 이러한 특징은 데이터 자체를 그냥 보았을 때 몰랐던 정보이다.
  • 데이터의 축약은 세부적인 수치를 희생시키지만 이 희생으로 데이터의 분포와 그 이면에 있는 특징들이 돋보이게 된다.
    • 즉 데이터의 축약은 요점을 정리하는 작업

 예제의 히스토그램

도수분표표 히스토그램

출처: 세상에서 가장 쉬운 통계학 입문

SQL 쿼리 튜토리얼: 특정 패턴을 만족하는 도시 이름 조회하기

데이터베이스에서 정보를 추출하는 것은 데이터 과학 및 소프트웨어 개발에서 매우 중요한 기술입니다. 오늘은 특정 조건을 만족하는 데이터를 조회하는 방법에 대해 알아보겠습니다.

1. 테이블 구조

먼저, 우리가 작업할 데이터베이스 테이블인 STATION의 구조부터 살펴보겠습니다. 이 테이블은 다음과 같은 필드를 포함하고 있습니다:

FieldType

ID NUMBER
CITY VARCHAR2(21)
STATE VARCHAR2(2)
LAT_N NUMBER
LONG_W NUMBER

이 테이블에서 CITY 필드는 도시 이름을 저장하며, 문자형 데이터로 최대 21자까지 입력 가능합니다.

2. 쿼리 목표

우리의 목표는 모음으로 시작하거나 모음으로 끝나지 않는 도시 이름을 조회하는 것입니다. 결과는 중복 없이 제공되어야 합니다.

3. SQL 쿼리

다음 SQL 쿼리는 위의 조건을 만족하는 도시 이름을 STATION 테이블에서 조회합니다

 

SELECT DISTINCT CITY
FROM STATION
WHERE CITY NOT LIKE 'A%' AND CITY NOT LIKE 'E%' AND CITY NOT LIKE 'I%' AND CITY NOT LIKE 'O%' AND CITY NOT LIKE 'U%'
AND CITY NOT LIKE '%a' AND CITY NOT LIKE '%e' AND CITY NOT LIKE '%i' AND CITY NOT LIKE '%o' AND CITY NOT LIKE '%u';

 

4. 결론

이 튜토리얼을 통해 SQL의 강력한 패턴 매칭 기능과 중복 제거 기능을 사용하여 원하는 데이터를 정확하게 추출할 수 있는 방법을 배웠습니다. 데이터베이스에서 정보를 효과적으로 처리하고 관리하는 능력은 다양한 프로젝트와 직무에서 큰 이점을 제공합니다.

'SQL' 카테고리의 다른 글

Employee Names  (1) 2024.09.28
Higher Than 75 Marks  (0) 2024.09.26
Weather Observation Station 11  (0) 2024.09.23
Weather Observation Station 10  (2) 2024.09.22
Weather Observation Station 9  (0) 2024.09.20

SQL 쿼리 문제 해결: 도시 이름 필터링

문제 설명

데이터베이스의 'STATION' 테이블에서 'CITY' 컬럼을 조회하는 작업에서, 특정 조건에 맞는 도시 이름을 추출해야 하는 문제를 다룹니다. 우리가 해결해야 할 문제는 도시 이름이 모음으로 시작하지 않거나 모음으로 끝나지 않는 도시를 찾는 것입니다. 또한, 결과에 중복된 도시 이름이 없어야 합니다.

 

테이블 구조

'STATION' 테이블의 구조는 다음과 같습니다:

FieldType

ID NUMBER
CITY VARCHAR2(21)
STATE VARCHAR2(2)
LAT_N NUMBER
LONG_W NUMBER

 

조건

  • 도시 이름은 모음(A, E, I, O, U)으로 시작하거나 끝나면 안 됩니다.
  • 결과는 중복 없이 유일한 도시 이름만 포함해야 합니다.

SQL 쿼리

이 문제를 해결하기 위한 SQL 쿼리는 다음과 같습니다:

SELECT DISTINCT CITY
FROM STATION
WHERE CITY NOT LIKE 'A%' AND CITY NOT LIKE 'E%' AND CITY NOT LIKE 'I%' AND CITY NOT LIKE 'O%' AND CITY NOT LIKE 'U%'
OR CITY NOT LIKE '%a' AND CITY NOT LIKE '%e' AND CITY NOT LIKE '%i' AND CITY NOT LIKE '%o' AND CITY NOT LIKE '%u';

 

쿼리 설명

이 쿼리는 STATION 테이블에서 CITY 필드를 검색합니다. WHERE 절은 도시 이름이 모음으로 시작하지 않거나 모음으로 끝나지 않는 조건을 검사합니다. 'AND'와 'OR' 연산자의 적절한 사용으로, 어느 한 조건이라도 만족하는 도시 이름을 선택합니다. DISTINCT 키워드는 중복을 제거하여 각 도시 이름이 한 번씩만 나타나도록 합니다.

결과

이 쿼리 실행 결과, 도시 이름이 예를 들어 "Boston"이나 "Phoenix"와 같이 모음으로 시작하거나 끝나지 않는 도시들이 추출됩니다. 도시 이름이 "Anaheim"이나 "Irvine"과 같이 모음으로 시작하는 경우는 제외됩니다.

'SQL' 카테고리의 다른 글

Higher Than 75 Marks  (0) 2024.09.26
Weather Observation Station 12  (2) 2024.09.24
Weather Observation Station 10  (2) 2024.09.22
Weather Observation Station 9  (0) 2024.09.20
Weather Observation Station 8  (1) 2024.09.19

SQL 문제 해결하기: 모음으로 끝나지 않는 도시 이름 찾기

테이블 구조

다음은 'STATION' 테이블의 구조를 나타내는 표입니다. 우리의 쿼리에서는 'CITY' 필드에 주목할 것입니다.

FieldType

ID NUMBER
CITY VARCHAR2(21)
STATE VARCHAR2(2)
LAT_N NUMBER
LONG_W NUMBER

문제 정의

이 SQL 문제에서는 'STATION' 테이블의 데이터 중에서 도시 이름(CITY)이 모음(a, e, i, o, u)으로 끝나지 않는 도시들을 찾아야 합니다. 또한, 결과에 도시 이름이 중복되지 않도록 해야 합니다.

SQL 쿼리 작성

  1. 중복 제거: DISTINCT 키워드를 사용하여 도시 이름이 중복되지 않게 합니다.
  2. 조건 설정: NOT LIKE 연산자를 사용하여 도시 이름이 특정 모음으로 끝나지 않도록 조건을 설정합니다.

SQL 쿼리

SELECT DISTINCT CITY
FROM STATION
WHERE CITY NOT LIKE '%a' AND CITY NOT LIKE '%e' AND CITY NOT LIKE '%i' AND CITY NOT LIKE '%o' AND CITY NOT LIKE '%u';

 

쿼리 설명

  • SELECT DISTINCT CITY: 'CITY' 필드에서 중복되지 않는 값을 선택합니다.
  • FROM STATION: 'STATION' 테이블에서 데이터를 조회합니다.
  • WHERE 조건: 도시 이름이 'a', 'e', 'i', 'o', 'u'로 끝나지 않는 도시만 선택하도록 조건을 설정합니다. 각 모음에 대해 NOT LIKE '%<모음>'을 사용하여 해당 조건을 충족합니다.

실행 결과

이 쿼리를 실행하면 모음으로 끝나지 않는 도시 이름을 중복 없이 조회할 수 있습니다. 실제 데이터베이스의 내용에 따라 결과는 다르게 나타날 수 있지만, 이 쿼리는 주어진 조건을 충족하는 모든 도시 이름을 정확히 필터링할 것입니다.

이와 같은 방식으로 SQL 쿼리를 작성하고 이해하는 방법을 익히면 다양한 데이터베이스 문제를 효과적으로 해결할 수 있습니다  감사합니다.

'SQL' 카테고리의 다른 글

Weather Observation Station 12  (2) 2024.09.24
Weather Observation Station 11  (0) 2024.09.23
Weather Observation Station 9  (0) 2024.09.20
Weather Observation Station 8  (1) 2024.09.19
Weather Observation Station 7  (1) 2024.09.16

+ Recent posts