서브쿼리(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개
게시글 목록
| 번호 | 제목 |
|---|---|
| 32071 | |
| 32070 | |
| 18535 |
JavaScript
ajax 그리드 문의
1
|
| 5369 | |
| 27088 | |
| 5364 | |
| 32069 | |
| 32068 | |
| 18521 |
jQuery
jquery 속도 높이는 팁
13
|
| 5359 | |
| 18520 |
jQuery
Easing Functions Cheat Sheet
|
| 32067 | |
| 32066 | |
| 27081 | |
| 18514 | |
| 5355 | |
| 5354 | |
| 5350 | |
| 32065 | |
| 18510 | |
| 18503 |
jQuery
좌우 슬라이드메뉴와 상하 슬라이드 메뉴
6
|
| 32064 | |
| 32063 | |
| 18502 | |
| 18499 | |
| 18495 | |
| 5345 | |
| 27079 | |
| 30718 | |
| 18494 | |
| 18493 | |
| 5343 | |
| 18491 | |
| 18489 | |
| 18487 |
Mobile
모바일 웹 개발에 큰 도움이 되는 피모 브라우저
1
|
| 18486 |
PHP
간단한 쿠폰번호 생성
|
| 18484 |
PHP
xml 파싱 예제
1
|
| 18482 |
PHP
eval
1
|
| 32062 | |
| 26476 |
제안서
제안서 유용한 도형
13
|
| 18481 |
jQuery
롤오버+슬라이드 질문드립니다.
|
| 5339 | |
| 18480 |
jQuery
jQuery path plugin
|
| 18476 |
JavaScript
아이폰일때 상단 검색바 숨기기
3
|
| 27137 | |
| 30711 | |
| 18475 | |
| 18474 | |
| 18470 | |
| 32061 | |
| 18469 | |
| 32060 | |
| 5335 | |
| 32059 | |
| 5333 | |
| 32058 |
센스리더
센스리더의 메뉴 구성 - 7. 도움말
|
| 32057 |
센스리더
센스리더의 메뉴 구성 - 6. 보기
|
| 30705 | |
| 5326 | |
| 18466 | |
| 18462 |
JavaScript
모바일웹 이미지맵 사용 소스
3
|
| 18461 |
JavaScript
[복사하기] 버튼 자료~
|
| 31504 | |
| 30696 | |
| 32056 |
센스리더
센스리더의 메뉴 구성 - 5. 점자
|
| 5321 | |
| 18456 |
PHP
php 동영상 강좌
4
|
| 18455 |
jQuery
array toggle
|
| 32055 |
센스리더
센스리더의 메뉴 구성 - 4. 도구
|
| 5315 | |
| 5310 |
MySQL
필드순서 바꾸는 명령 있을까요?
4
|
| 27072 | |
| 32054 | |
| 27066 | |
| 18453 | |
| 30692 |
HTML
IE6 PNG 초 간단하게 적용
3
|
| 30690 | |
| 18451 | |
| 18450 | |
| 18449 | |
| 5307 | |
| 32051 | |
| 18448 | |
| 18447 | |
| 18441 |
jQuery
참고사이트 모음
5
|
| 18437 | |
| 18429 | |
| 32049 | |
| 30686 | |
| 5299 | |
| 5289 | |
| 30677 | |
| 32042 |
센스리더
센스리더에서 사용되는 개념들
6
|
| 18426 | |
| 18422 | |
| 18420 | |
| 18418 | |
| 5285 | |
| 5282 | |
| 26459 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기