데이터 베이스 MySQL 튜토리얼 실제 사례를 이용한 SQL 필터링 및 정렬

실제 사례를 이용한 SQL 필터링 및 정렬

Jan 01, 2025 am 02:41 AM

SQL Filtering and Sorting with Real-life Examples

이 블로그에서는 WHERE, HAVING, ORDER BY, GROUP BY 등의 SQL 절과 기타 관련 절을 직원 및 부서 테이블을 실제 사례를 통해 설명합니다.

목차

  1. 테이블 구조
  2. WHERE 절
  3. GROUP BY 절
  4. HAVING 절
  5. ORDER BY 조항
  6. LIMIT 조항
  7. DISTINCT 조항
  8. AND, OR, NOT 연산자

테이블 구조

직원 테이블

emp_id name age department_id hire_date salary
1 John Smith 35 101 2020-01-01 5000
2 Jane Doe 28 102 2019-03-15 6000
3 Alice Johnson 40 103 2018-06-20 7000
4 Bob Brown 55 NULL 2015-11-10 8000
5 Charlie Black 30 102 2021-02-01 5500

부서 테이블

dept_id dept_name
101 HR
102 IT
103 Finance
104 Marketing

WHERE 절

WHERE 절은 지정된 조건에 따라 레코드를 필터링하는 데 사용됩니다.

SQL 쿼리

SELECT name, age, salary
FROM employees
WHERE age > 30;
로그인 후 복사
로그인 후 복사
로그인 후 복사

결과

name age salary
John Smith 35 5000
Alice Johnson 40 7000
Bob Brown 55 8000

설명: WHERE 절은 30세 이상의 직원만 포함하도록 행을 필터링합니다.

AND 연산자의 예

SELECT name, age, salary
FROM employees
WHERE age > 30 AND salary > 5000;
로그인 후 복사
로그인 후 복사
로그인 후 복사

결과

name age salary
Alice Johnson 40 7000
Bob Brown 55 8000

설명: WHERE 절은 30세 이상, 급여가 5000 이상인 직원을 필터링합니다.


GROUP BY 절

GROUP BY 절은 각 부서의 직원 수를 찾는 것과 같이 동일한 값을 가진 행을 요약 행으로 그룹화하는 데 사용됩니다.

SQL 쿼리

SELECT name, age, salary
FROM employees
WHERE age > 30;
로그인 후 복사
로그인 후 복사
로그인 후 복사

결과

department_id employee_count
101 1
102 2
103 1

설명: GROUP BY 절은 직원을 Department_id별로 그룹화하고 각 부서의 직원 수를 계산합니다.


HAVING 절

HAVING 절은 GROUP BY 절로 생성된 그룹을 필터링하는 데 사용됩니다. WHERE 절과 동일하게 작동하지만 집계 후에 사용됩니다.

SQL 쿼리

SELECT name, age, salary
FROM employees
WHERE age > 30 AND salary > 5000;
로그인 후 복사
로그인 후 복사
로그인 후 복사

결과

department_id avg_salary
102 5750
103 7000

설명: HAVING 절은 각 부서 직원의 평균 급여를 기준으로 그룹을 필터링합니다. 평균연봉이 5500 이상인 부서만 포함됩니다.


ORDER BY 조항

ORDER BY 절은 하나 이상의 열을 기준으로 결과 집합을 정렬하는 데 사용됩니다. 기본적으로 오름차순으로 정렬됩니다. 내림차순으로 정렬하려면 DESC를 사용하세요.

SQL 쿼리(오름차순)

SELECT department_id, COUNT(*) AS employee_count
FROM employees
GROUP BY department_id;
로그인 후 복사
로그인 후 복사

결과

name salary
John Smith 5000
Charlie Black 5500
Jane Doe 6000
Alice Johnson 7000
Bob Brown 8000

설명: 급여 기준 오름차순으로 정렬된 결과입니다.

SQL 쿼리(내림차순)

SELECT department_id, AVG(salary) AS avg_salary
FROM employees
GROUP BY department_id
HAVING AVG(salary) > 5500;
로그인 후 복사
로그인 후 복사

결과

name salary
Bob Brown 8000
Alice Johnson 7000
Jane Doe 6000
Charlie Black 5500
John Smith 5000

설명: 급여 내림차순으로 정렬된 결과입니다.


LIMIT 조항

LIMIT 절은 결과 집합에서 반환할 레코드 수를 지정하는 데 사용됩니다. 이는 대규모 결과 세트를 페이징하거나 제한하는 데 특히 유용합니다.

SQL 쿼리

SELECT name, age, salary
FROM employees
WHERE age > 30;
로그인 후 복사
로그인 후 복사
로그인 후 복사

결과

name salary
Bob Brown 8000
Alice Johnson 7000
Jane Doe 6000

설명: LIMIT 절은 급여가 가장 높은 직원 상위 3명으로만 출력을 제한합니다.


DISTINCT 조항

DISTINCT 절은 결과 집합에서 고유한(다른) 값만 반환하고 중복을 제거하는 데 사용됩니다.

SQL 쿼리

SELECT name, age, salary
FROM employees
WHERE age > 30 AND salary > 5000;
로그인 후 복사
로그인 후 복사
로그인 후 복사

결과

department_id
101
102
103

설명: DISTINCT 절은 중복을 제거하여 고유한 Department_id 값을 반환합니다.


AND, OR, NOT 연산자

AND, ORNOT 연산자는 WHERE 절에서 여러 조건을 결합하는 데 사용됩니다.

AND 연산자

AND 연산자는 두 개 이상의 조건을 결합하는 데 사용됩니다. 결과에는 모든 조건이 true인 행만 포함됩니다.

SELECT department_id, COUNT(*) AS employee_count
FROM employees
GROUP BY department_id;
로그인 후 복사
로그인 후 복사

결과

name age salary
Alice Johnson 40 7000
Bob Brown 55 8000

설명: WHERE 절은 두 조건(연령 > 30 및 급여 > 5500)이 모두 참인 행을 필터링합니다.

OR 연산자

OR 연산자는 조건 중 하나만 참이어야 하는 경우에 사용됩니다.

SELECT department_id, AVG(salary) AS avg_salary
FROM employees
GROUP BY department_id
HAVING AVG(salary) > 5500;
로그인 후 복사
로그인 후 복사

결과

name age salary
Jane Doe 28 6000
Alice Johnson 40 7000
Bob Brown 55 8000

설명: WHERE 절은 age < 30 또는 급여 > 7000이 맞습니다.

NOT 연산자

NOT 연산자는 조건이 true인 행을 제외하는 데 사용됩니다.

SELECT name, age, salary
FROM employees
WHERE age > 30;




결과

name age salary
John Smith 35 5000
Charlie Black 30 5500
Jane Doe 28 6000

설명: WHERE 절은 급여 > 6000은 거짓입니다. 즉, 급여가 6000 이하인 직원을 반환한다는 의미입니다.


결론

이 블로그에서는 직원 및 부서 테이블의 실제 예와 함께 SQL의 WHERE, HAVING, ORDER BY, GROUP BY 및 기타 절을 사용하여 데이터를 필터링, 그룹화 및 정렬하는 방법을 설명합니다. 효율적인 SQL 쿼리 작성, 데이터 분석, 데이터베이스 관리를 효과적으로 수행하려면 이러한 조항을 이해하는 것이 중요합니다.

위 내용은 실제 사례를 이용한 SQL 필터링 및 정렬의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Docker에서 MySQL 메모리 사용을 줄입니다 Docker에서 MySQL 메모리 사용을 줄입니다 Mar 04, 2025 pm 03:52 PM

Docker에서 MySQL 메모리 사용을 줄입니다

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까? Mar 19, 2025 pm 03:51 PM

Alter Table 문을 사용하여 MySQL에서 테이블을 어떻게 변경합니까?

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다. Mar 04, 2025 pm 04:01 PM

MySQL의 문제를 해결하는 방법 공유 라이브러리를 열 수 없습니다.

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음) Mar 04, 2025 pm 03:54 PM

Linux에서 MySQL을 실행합니다 (Phpmyadmin이있는 Podman 컨테이너가 포함되지 않음)

sqlite 란 무엇입니까? 포괄적 인 개요 sqlite 란 무엇입니까? 포괄적 인 개요 Mar 04, 2025 pm 03:55 PM

sqlite 란 무엇입니까? 포괄적 인 개요

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드 Mar 04, 2025 pm 03:49 PM

MacOS에서 여러 MySQL 버전을 실행 : 단계별 가이드

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까? Mar 18, 2025 pm 12:01 PM

MySQL 연결에 대한 SSL/TLS 암호화를 어떻게 구성합니까?

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? 인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)? Mar 21, 2025 pm 06:28 PM

인기있는 MySQL GUI 도구는 무엇입니까 (예 : MySQL Workbench, Phpmyadmin)?

See all articles