메뉴 건너뛰기

2017.11.16 20:03

서브쿼리

조회 수 3444 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄 첨부

서브쿼리

서브쿼리를 사용하면 질의를 실행해서 추출한 데이터를 이용해서 다시 질의를 실행하는 2단계의 처리를 할 수 있다.


ex) select * from tb where max(sales);

 

위 쿼리를 사용하면 에러가 납니다. 이유는 쿼리문에서 준 조거 max(sales) 조건의 값을 아직 알지 못하기 때문입니다.


따라서 다음과 같은 조건을 만족시키기 위해서는 아래 서브쿼리를 사용 쿼리문을 사용해야합니다.

ex) select * from tb where sales in (select max(sales) from tb);

 

in(?)에서 ?부분이 1단계 쿼리부분입니다. 즉 1단계 쿼리문의 결과에 대한 2단계 값을 추출하는 과정입니다.


ex) select * from tb1 where age >= (select avg(age) from tb1);

 


첫번째 쿼리문과 이번 쿼리문의 차이는 in의 유무입니다.

잘 비고해서 생각해 보기 바랍니다.


다음과 같이 두테이블에 서브쿼리를 적용한 예입니다.

ex) select * from tb1 where number in (select number from tb where sales>=200);

 



만약 in 대신 등호를 사용한다면?

 

다음과 같은 에러가나는데 이유는 number = '하위쿼리 결과값' 인데 이때 하위쿼리의 결과값이 하나가 아니기 때문이다.

에러구문이 설명해 주고 있는 내용이다.


따라서 다음과 같은 구문으로 에러는 피할 수 있지만, 올바른 방법은 아니다.

 


  1. No Image 12Apr
    by
    2017/04/12 Views 5392 

    [MySQL] 백업 및 복구

  2. No Image 12Apr
    by
    2017/04/12 Views 5330 

    MySQL 손상된 테이블 복구

  3. No Image 12Apr
    by
    2017/04/12 Views 5727 

    MySQL 에서 랜덤(random)으로 레코드 읽어오기

  4. No Image 12Apr
    by
    2017/04/12 Views 5252 

    MySQL root 패스워드 분실시

  5. No Image 12Apr
    by
    2017/04/12 Views 6053 

    MySQL 쿼리 결과 값 세로로 보기

  6. No Image 12Apr
    by
    2017/04/12 Views 5272 

    테이블 타입(Heap, MyIsam, InnoDB...) 변경하기

  7. No Image 12Apr
    by
    2017/04/12 Views 5071 

    백업시 캐릭터셋(charset) 지정하기

  8. 세자리 마다 콤마 찍기

  9. flush privileges 명령어

  10. No Image 12Apr
    by
    2017/04/12 Views 5352 

    MySQL JOIN 걸어서 UPDATE 하기

  11. mysql(union,join)

  12. 서브쿼리

  13. mysql(exists, not exists)

  14. No Image 16Nov
    by
    2017/11/16 Views 5076 

    다른 테이블 데이터를 원하는 테이블에 업데이트 시키기

  15. No Image 16Nov
    by
    2017/11/16 Views 8865 

    특정 COLUMN을 제외하고 SELECT/INSERT하는 방법

  16. No Image 21Nov
    by
    2017/11/21 Views 3918 

    Union 사용법. 여러 테이블의 같은 값을 한번 쿼리로 추출하기

  17. No Image 21Nov
    by
    2017/11/21 Views 5388 

    두 테이블을 비교하여 한쪽테이블에는 있지만 다른 테이블에는 없는 값을 뽑아내보자!

  18. Mysql Join 해부(Left, Right, Outer, Inner Join)

  19. MySQL Shard 데이터 재분배

  20. MySQL 파티션 개요

Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved