서브쿼리(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개
게시글 목록
| 번호 | 제목 |
|---|---|
| 18790 |
JavaScript
공백제거
|
| 18788 |
PHP
셀렉트박스 간편하게 만들기
1
|
| 18786 | |
| 18783 |
PHP
게시판의 페이징 방법
2
|
| 18780 |
PHP
이미지에 워터마크 처리하기
2
|
| 18769 |
Mobile
Chrome 를 이용한 모바일모드
10
|
| 5549 | |
| 27272 | |
| 27267 | |
| 30785 | |
| 30782 | |
| 27264 | |
| 18767 |
JavaScript
스크립트오류 제거
1
|
| 18765 |
JavaScript
간단한 쿠키지원 팝업 스크립트
1
|
| 18764 | |
| 18763 |
JavaScript
대소문자변환
|
| 5546 | |
| 18760 | |
| 18758 | |
| 18755 |
JavaScript
홈페이지 브라우저 크기 고정시키기
2
|
| 18752 |
JavaScript
iframe 아이프레임 투명처리
2
|
| 27256 | |
| 27247 | |
| 5539 | |
| 18750 | |
| 27244 | |
| 27243 | |
| 18749 |
JavaScript
금액 입력시 자동으로 천단위구분기호(,) 붙여주는 함수
|
| 18747 | |
| 18745 |
JavaScript
출생년도에 따른 나이 계산 자바스크립트
1
|
| 18741 | |
| 18740 | |
| 18738 |
JavaScript
iframe에서 페이지를 닫을 때
1
|
| 18731 |
JavaScript
iframe 높이 자동조절 스크립트
6
|
| 18730 |
JavaScript
자바스크립트 인공지능 장기게임-Minimax
|
| 27240 | |
| 5535 | |
| 18728 |
JavaScript
금액을 한글로 표기 해주는 스크립트;
1
|
| 18726 |
JavaScript
전화번호 입력시 자동 하이픈 넣기
1
|
| 18724 |
JavaScript
사업자번호체크스크립트 간단버전
1
|
| 5532 | |
| 26500 |
견적서
홈페이지 제작 견적서
14
|
| 27237 | |
| 5529 | |
| 30776 | |
| 18721 |
jQuery
플러그인 만들기 간단 예제
2
|
| 20725 | |
| 27232 | |
| 18719 |
JavaScript
퀵메뉴
1
|
| 18717 | |
| 18714 |
JavaScript
입력박스안에 왠 아이콘?
2
|
| 18712 |
JavaScript
게시판 글작성시 일부 태그막기
1
|
| 18709 |
jQuery
랜덤한 레이아웃과 효과
2
|
| 27213 | |
| 27200 | |
| 18706 |
JavaScript
자동으로 textarea 크기 조절하기
2
|
| 18704 |
JavaScript
textarea 자동 늘려주기 2
1
|
| 18702 |
JavaScript
해당 브라우저에 지원하는 이벤트 확인
1
|
| 18701 |
JavaScript
자바스크립트로 논리적인 XOR 연산하기.
|
| 18700 |
JavaScript
동적 셀렉트박스 다루기.
|
| 18698 |
JavaScript
자바스크립트 이벤트 핸들러 (Event Handler)
1
|
| 18697 |
JavaScript
함수명을 변수로 해야할 때
|
| 18696 |
JavaScript
이메일 유효성 정규식 - 자바스크립트
|
| 18694 | |
| 5525 | |
| 27199 | |
| 18691 | |
| 5515 | |
| 5510 | |
| 5501 | |
| 18690 | |
| 18687 | |
| 5496 | |
| 18686 | |
| 18676 | |
| 26496 |
서식
영수증 양식
3
|
| 18675 | |
| 30773 | |
| 18671 |
JavaScript
이미지 슬라이드 관련입니다.(자바,제이쿼리)
3
|
| 30767 | |
| 18667 |
JavaScript
롤오버시 서브메뉴가 나타나는 기본 스크립트
3
|
| 18658 |
jQuery
회사에 히스토리에 써먹을 만한 자료
8
|
| 18650 | |
| 18648 |
MySQL
고수님들 도와주세요!
1
|
| 5494 | |
| 5490 | |
| 20705 | |
| 5485 | |
| 18645 |
Mobile
json 파싱방법
2
|
| 27194 | |
| 20684 |
정규표현식
정규표현식 의 핵심. 패턴변경자 1
20
|
| 18642 | |
| 5482 | |
| 27185 | |
| 5478 | |
| 5473 | |
| 5467 | |
| 18636 | |
| 5462 | |
| 5443 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기