DB

[SQL]서브쿼리

2023. 3. 28. 16:04

1.왜 서브쿼리를 쓰는가?

1.1 SELECT절의 순서를 바꾸기 위해 사용한다. 

SELECT * FROM MEMBER WHERE ROWNUM BETWEEN 1 AND 10

위의 SQL문을 최신 등록순으로 정렬한 결과를 상위 열명을 나타내기 위해선 다음과 같은 SQL문을 생각할 수 있다.

SELECT * 
FROM MEMBER
ORDER BY REGDATE DESC
WHERE ROWNUM BETWEEN 1 AND 10

하지만 SQL문을 실행하면 오류가 생긴다. ORDER BY 절은 WHERE절 다음에 와야한다. 하지만 순서를 지키지 않았기 때문에 문제가 생긴다. 즉 쿼리 실행순서 오류다. SQL 실행순서에 따르면 위의 조건(최신 등록순으로 정렬한 결과를 상위 열명을 나타내기)를 만족하는 SQL문을 짤 수 없다. 그래서 서브쿼리를 활용한다.

 

SELECT * 
FROM (SELECT * FROM MEMBER ORDER BY REGDATE DESC)
WHERE ROWNUM BETWEEN 1 AND 10

 

서브쿼리를 활용해 SQL문을 짜면 SQL실행순서에 위배되지 않고 실행할 수 있다.

 

1.2 WHERE절에 집계함수를 써야하는 경우

WHERE절은 집계함수(SUM,MIN,MAX,COUNT,AVG)를 쓸 수 없다. 하지만 서브쿼리를 활용하면 WHERE절에 집계함수를 쓴 것과 같은 효과를 볼 수 있다. 만약 평균나이 이상(30)인 회원을 출력하는 SQL문을 짠다고 가정해보자. 서브쿼리를 사용하지 않으면 다음과 같은 SQL문을 짤 것이다. WHERE절은 집혜함수를 쓸 수 없을 뿐더러 평균값은 매번 바뀌기 때문에 오류가 발생한다.

SELECT * FROM MEMBER
WHERE AVG(AGE) >= 30

 

하지만 여기에 서브 쿼리를 사용해준다면 똑같은 결과물을 나타내는 SQL문을 작성할 수 있다.

SELECT * FROM MEMBER
WHERE AGE >= (SELECT AVG(AGE) FROM MEMBER
각시탈코더
각시탈코더
각시탈코더
각시탈코더
각시탈코더
전체
오늘
어제
  • 분류 전체보기 (203)
    • java (46)
      • 객체지향 (20)
      • 기본문법 (8)
      • 자바의 정석 연습문제 오답노트 (9)
      • 백준 알고리즘 (9)
    • Spring (17)
      • SpringMVC (8)
      • Spring DI와 AOP (5)
      • REST API와 Ajax (1)
      • Spring 프로젝트 (1)
      • Spring Security (0)
    • DB (47)
      • Oracle (15)
      • SQL오답노트 (25)
      • 튜닝 (0)
      • ERD (1)
      • DB 모델링 (5)
    • Servlet & JSP (3)
    • JDBC (2)
      • 기본 (1)
      • 스프링JDBC (1)
    • MyBatis (2)
    • JavaScript (2)
      • 코딩애플 (0)
      • 문법 (1)
    • React (0)
      • 코딩애플 (0)
    • HTML (0)
      • 모던 웹을 위한 HTML5+CSS3 바이블 (0)
    • CSS (0)
      • 모던 웹을 위한 HTML5+CSS3 바이블 (0)
    • Linux (0)
    • Git & GitHub (2)
      • Git (1)
    • CS (19)
      • 네트워크 (6)
      • HTTP (7)
      • 컴퓨터구조 (0)
      • 자료구조와 알고리즘 (2)
      • 기타 (4)
    • 개발설정 (2)
    • 기술면접 (0)
      • JAVA (0)
      • Spring (0)
      • DB (0)
      • 네트워크 (0)
      • 공통 (0)
    • 프로젝트 (2)
      • 게시판만들기 (2)
    • 기혁씨의 삽질표류기 (28)
    • 참고자료 (2)
      • 국비수업 (0)
      • 당당 프로젝트 (1)
    • 뉴렉처 (17)
      • 자바 (11)
      • 자바스크립트 (3)
      • 키워드 (0)
      • 숙제 (0)
      • CSS (0)
      • DB (3)
      • 서블릿 (0)
      • 스프링 (0)
      • DOM (0)
    • 내가 만든 학습그림 (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 에러
  • 쿼리
  • db
  • Oracle
  • 백준
  • 스프링
  • 객체지향
  • 뉴렉처
  • 서브쿼리
  • 네트워크
  • Java
  • 배열
  • 알고리즘
  • 백엔드
  • 웹프로그래밍
  • SQL
  • spring
  • 공부
  • 국비수업
  • 자바의정석기초편
  • 자바
  • 연습문제
  • 오라클
  • 자바의정석
  • 코딩
  • 모두의네트워크
  • 프로그래머스
  • 개발자
  • It
  • 오류

최근 댓글

최근 글

hELLO · Designed By 정상우.
각시탈코더
[SQL]서브쿼리
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.