서브쿼리(SubQuery)
- 하나의 SQL문 안에 포함되어 있는 또 다른 SQL문을 말한다.
Select some_column, another_column
From table
Where column = (Select column From table);
검은색 : 외부쿼리, 빨간색 : 내부 쿼리, 서브쿼리
서브쿼리 조건
1. 서브쿼리는 언제나 Select 문 하나다.
2. 서브쿼리는 항상 괄호 안에 있어야 한다.
3. 서브쿼리는 세미콜론이없다. 세미콜론은 항상 전체 쿼리의 마지막에 위치한다.
4. 서브쿼리는 쿼리문의 4 곳에 나올 수 있다.
- Select절, 열들의 하나로 열 리스트를 선택하는 경우, From 절, Having 절.
5. 서브쿼리는 Select뿐 아니라 Insert, Delete, Update와 함께 사용될 수 있다.
서브쿼리 사용히 주의할 사항
1. 서브쿼리는 괄호로 감싸서 사용한다.
2. 서브쿼리는 단일 행(Single Row) 또는 복수 행(Multiple Row) 비교 연산자와 함께 사용 가능하다.
단일 행 비교 연산는 서브쿼리의 결과가 반드시 1건 이하여야 하고,
복수 행 비교 연산자는 서브쿼리의 결과 건수과 상관없다.
3. 서브쿼리에서는 Order by 절을 사용하지 못한다. Order by 절은 Select 절에서 오직 한개만 올 수
있기때문에 Order by 절은 메인 쿼리의 마지막 문장에 위치해야 한다.
예) Where절에서 서브쿼리 사용
Select last_name, first_name
From my_contacts
WHERE zip_code = (Select zip_code From zip_code Wherer city = 'Memphis' And state = 'IN');
예) 자연 조인을 포함한 서브쿼리문
Select mc.first_name, mc.last_name, mc.phone, jc.title
From job_current AS jc
Natural Join my_contacts AS mc
Where jc.title IN (Select title From job_listings);
예) Select절에서 서브쿼리 사용
Seletc mc.first_name, mc.last_name,
(Select state From zip_code Where mc.zip_code = zip_code) AS state
From my_contacts mc;
비상관 쿼리
- 만약 서브쿼리가 외부쿼리의 어떤 것도 참조하지 않고 단독으로 사용되면 비상관 쿼리라고 한다.
- 내부쿼리가 우선 실행되고 외부쿼리로 이동한다.
* 여러 값을 반환하는 비상관 서브쿼리 : IN, NOT IN
- 비상관 서브 쿼리는 In이나 NOT IN을 사용하여 값이 서브쿼리에서 반환된 집합의
원소인지(아닌지)를 확인한다.
유용한 예) 리스트에 없는 직업 이름을 찾자
Select mc.first_name, mc.last_name, mc.phone, jc.title
From job_current jc Natural Join my_contacts mc
Where jc.title Not In (Select title From job_listings);
상관 쿼리
- 외부 쿼리에 의존적이다.
아래 예를 살펴보자
Select mc.first_name, mc.last_name
From my_contacts AS mc
Where 3 = (Select Count(*) From contact_interest Where contact_id = mc.contact_id);
서브쿼리가 별명 mc를 참조한다. 외부쿼리가 실행되어야 mc.contact_id의 값을 알 수 있다.
그러므로 서브쿼리는 외부쿼리에 의존적인 것을 알 수 있다.
유용한 예) 외부쿼리에 있는 행들에서 관련 테이블에 없는 모든 행을 찾자
my_contacts의 사람들 중 job_current 테이블에 없는 모든 사람을 찾는다.
Select mc.first_name firstname, mc.last_name lastname, mc.email email
From my_contacts mc
Where Not Exists (Select * From job_current jc Where mc.contact_id = jc.contact_id);
* 참고 : Exist와 Not Exists는 서로 반대의 의미이다.
출처 : http://warmz.tistory.com
- 하나의 SQL문 안에 포함되어 있는 또 다른 SQL문을 말한다.
Select some_column, another_column
From table
Where column = (Select column From table);
검은색 : 외부쿼리, 빨간색 : 내부 쿼리, 서브쿼리
서브쿼리 조건
1. 서브쿼리는 언제나 Select 문 하나다.
2. 서브쿼리는 항상 괄호 안에 있어야 한다.
3. 서브쿼리는 세미콜론이없다. 세미콜론은 항상 전체 쿼리의 마지막에 위치한다.
4. 서브쿼리는 쿼리문의 4 곳에 나올 수 있다.
- Select절, 열들의 하나로 열 리스트를 선택하는 경우, From 절, Having 절.
5. 서브쿼리는 Select뿐 아니라 Insert, Delete, Update와 함께 사용될 수 있다.
서브쿼리 사용히 주의할 사항
1. 서브쿼리는 괄호로 감싸서 사용한다.
2. 서브쿼리는 단일 행(Single Row) 또는 복수 행(Multiple Row) 비교 연산자와 함께 사용 가능하다.
단일 행 비교 연산는 서브쿼리의 결과가 반드시 1건 이하여야 하고,
복수 행 비교 연산자는 서브쿼리의 결과 건수과 상관없다.
3. 서브쿼리에서는 Order by 절을 사용하지 못한다. Order by 절은 Select 절에서 오직 한개만 올 수
있기때문에 Order by 절은 메인 쿼리의 마지막 문장에 위치해야 한다.
예) Where절에서 서브쿼리 사용
Select last_name, first_name
From my_contacts
WHERE zip_code = (Select zip_code From zip_code Wherer city = 'Memphis' And state = 'IN');
예) 자연 조인을 포함한 서브쿼리문
Select mc.first_name, mc.last_name, mc.phone, jc.title
From job_current AS jc
Natural Join my_contacts AS mc
Where jc.title IN (Select title From job_listings);
예) Select절에서 서브쿼리 사용
Seletc mc.first_name, mc.last_name,
(Select state From zip_code Where mc.zip_code = zip_code) AS state
From my_contacts mc;
비상관 쿼리
- 만약 서브쿼리가 외부쿼리의 어떤 것도 참조하지 않고 단독으로 사용되면 비상관 쿼리라고 한다.
- 내부쿼리가 우선 실행되고 외부쿼리로 이동한다.
* 여러 값을 반환하는 비상관 서브쿼리 : IN, NOT IN
- 비상관 서브 쿼리는 In이나 NOT IN을 사용하여 값이 서브쿼리에서 반환된 집합의
원소인지(아닌지)를 확인한다.
유용한 예) 리스트에 없는 직업 이름을 찾자
Select mc.first_name, mc.last_name, mc.phone, jc.title
From job_current jc Natural Join my_contacts mc
Where jc.title Not In (Select title From job_listings);
상관 쿼리
- 외부 쿼리에 의존적이다.
아래 예를 살펴보자
Select mc.first_name, mc.last_name
From my_contacts AS mc
Where 3 = (Select Count(*) From contact_interest Where contact_id = mc.contact_id);
서브쿼리가 별명 mc를 참조한다. 외부쿼리가 실행되어야 mc.contact_id의 값을 알 수 있다.
그러므로 서브쿼리는 외부쿼리에 의존적인 것을 알 수 있다.
유용한 예) 외부쿼리에 있는 행들에서 관련 테이블에 없는 모든 행을 찾자
my_contacts의 사람들 중 job_current 테이블에 없는 모든 사람을 찾는다.
Select mc.first_name firstname, mc.last_name lastname, mc.email email
From my_contacts mc
Where Not Exists (Select * From job_current jc Where mc.contact_id = jc.contact_id);
* 참고 : Exist와 Not Exists는 서로 반대의 의미이다.
출처 : http://warmz.tistory.com
댓글 5개
게시글 목록
| 번호 | 제목 |
|---|---|
| 8265 | |
| 20403 | |
| 20402 | |
| 20401 | |
| 20400 |
웹서버
서버 동시접속자 설정 변경하기
|
| 8259 | |
| 20399 | |
| 20398 | |
| 8255 | |
| 8249 | |
| 8246 | |
| 8242 | |
| 20396 | |
| 8240 | |
| 20395 | |
| 20394 |
MySQL
테이블 복사 쿼리
|
| 31033 | |
| 28385 | |
| 20393 |
PHP
현재 접속중인 사용자 나타내기
|
| 28380 | |
| 20392 |
MySQL
mysql select 후 update 하기
|
| 28377 | |
| 20391 | |
| 20390 |
PHP
한글문자열 자르는 법 입니다.
|
| 20389 | |
| 20388 | |
| 20387 |
PHP
이메일주소 검사하기 입니다.
|
| 20386 | |
| 20385 | |
| 20384 |
node.js
Node js 게시판 프로젝트 소개합니다.
|
| 20383 |
PHP
pc 모바일 체크
1
|
| 20382 |
PHP
계정 사용량(용량) 확인
|
| 8238 | |
| 20380 | |
| 20379 |
MySQL
소수점 반올림 버림
|
| 28376 | |
| 28372 | |
| 20378 | |
| 20377 |
PHP
에러 로그파일 생성하기
|
| 8235 | |
| 20375 | |
| 20374 | |
| 20373 |
PHP
후이즈검색 하기 입니다.
|
| 20372 |
PHP
그래프 그리기 입니다.
|
| 20371 |
JavaScript
자바스크립트로 구현한 number_format() 입니다.
|
| 20370 |
JavaScript
금액 관련 숫자를 한글로 변환하기 입니다.
|
| 28370 | |
| 20369 |
PHP
PHP 날짜 계산 관련 함수
|
| 28366 | |
| 20368 |
jQuery
jQuery 1.x와 2.x 버전 동시에 사용하기
|
| 20367 | |
| 20366 | |
| 20365 |
JavaScript
사업자 등록번호 검사하기 입니다.
|
| 20364 | |
| 20363 |
JavaScript
항상 같은곳에 광고창 만들기 입니다.
|
| 20362 |
JavaScript
부메뉴 나오게 하기 입니다.
|
| 20361 |
JavaScript
특정문자 제거하기 입니다.
|
| 20360 |
JavaScript
휴대폰번호 검사 하기 입니다.
|
| 20359 |
JavaScript
이미지 좌우로 이동 갤러리 입니다.
|
| 8231 | |
| 20358 | |
| 20357 |
JavaScript
쉬운 replaceAll 입니다.
|
| 20356 | |
| 20355 | |
| 20354 | |
| 20353 | |
| 20352 |
JavaScript
콤보스타일 메뉴 입니다.
|
| 20351 |
JavaScript
쿠키를 이용한 레이어 공지창 입니다.
|
| 20350 |
JavaScript
효과있는 텍스트 틱커 입니다.
|
| 20349 | |
| 20348 |
PHP
HTTP 인증 하기 입니다.
|
| 20347 |
JavaScript
외부 문서 불러오기 입니다.
|
| 20346 |
JavaScript
지정한 날짜까지 New 이미지를 띄워주기 입니다.
|
| 20345 | |
| 20344 |
JavaScript
메일 주소 검사하기 체크박스 입니다.
|
| 20343 |
JavaScript
무단링크 금지하기 입니다.
|
| 20342 | |
| 20341 |
MySQL
DB백업 및 복원
|
| 20340 |
JavaScript
페이지가 다른 사이트의 프레임에 갇히는 것을 막기 입니다.
|
| 20339 | |
| 20338 | |
| 20337 |
jQuery
input text 대문자만 받는 Jquery
|
| 20336 | |
| 20335 |
JavaScript
이미지 업로드와 미리보기 입니다.
|
| 20334 |
JavaScript
배경음악 랜덤 재생 하기 입니다.
|
| 20333 |
JavaScript
css 지원 여부 확인해서 다른 페이지로 이동하기 입니다.
|
| 20332 |
JavaScript
하부메뉴가 보였다가 숨겨졌다 하는 토글버튼 입니다.
|
| 20331 |
JavaScript
개별 페이지에 인덱스로 거쳐 들어오게 하기 입니다.
|
| 20330 |
JavaScript
랜덤으로 이미지 출력 되기 입니다.
|
| 20329 |
JavaScript
사용자 해상도 알아내기 입니다.
|
| 20328 |
JavaScript
붙여넣기 금지하기 입니다.
|
| 20327 |
MySQL
대소문자 데이터 조회하기
|
| 20326 |
JavaScript
퇴장시 팝업창 한번한 띄우기 입니다.
|
| 20325 | |
| 20324 | |
| 20323 |
JavaScript
시도, 구군, 동 주소 select
|
| 20322 |
MySQL
커리로 DB 테이블 명세서 출력하기
|
| 20321 |
JavaScript
브라우저 해상도 구분없는 절대 x,y 좌표 값 구하기 입니다
|
| 20320 |
PHP
rss 읽어오기 입니다.
|
| 20319 |
JavaScript
자바스크립트로 Ajax 효과내기 입니다.
|
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기