서브쿼리(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개
joseehn
12년 전
감사합니다.
takumi22
12년 전
여기서 강의를??
mirrV
12년 전
기본적으로 생각해도 알 수 있는 기본적인 팁이네요.
12년 전
감사합니다.^^
12년 전
참고로 select 내에서 inner select로도 가능합니다.
게시판 목록
프로그램
| 번호 | 제목 | 글쓴이 | 날짜 | 조회 |
|---|---|---|---|---|
| 6530 |
퍼블리셔강
|
12년 전 | 654 | |
| 6529 | 12년 전 | 1313 | ||
| 6528 | 12년 전 | 631 | ||
| 6527 | 12년 전 | 794 | ||
| 6526 | 12년 전 | 6583 | ||
| 6525 | 12년 전 | 552 | ||
| 6524 | 12년 전 | 845 | ||
| 6523 | 12년 전 | 500 | ||
| 6522 | 12년 전 | 541 | ||
| 6521 | 12년 전 | 804 | ||
| 6520 | 12년 전 | 748 | ||
| 6519 | 12년 전 | 1749 | ||
| 6518 |
가슴시린하늘
|
12년 전 | 1728 | |
| 6517 | 12년 전 | 1368 | ||
| 6516 | 12년 전 | 5231 | ||
| 6515 | 12년 전 | 1505 | ||
| 6514 | 12년 전 | 1607 | ||
| 6513 | 12년 전 | 958 | ||
| 6512 | 12년 전 | 1992 | ||
| 6511 | 12년 전 | 1387 | ||
| 6510 | 12년 전 | 3079 | ||
| 6509 |
프로프리랜서
|
12년 전 | 2560 | |
| 6508 |
프로프리랜서
|
12년 전 | 1904 | |
| 6507 |
프로프리랜서
|
12년 전 | 2380 | |
| 6506 |
프로프리랜서
|
12년 전 | 1863 | |
| 6505 |
프로프리랜서
|
12년 전 | 1636 | |
| 6504 | 12년 전 | 1047 | ||
| 6503 | 12년 전 | 1140 | ||
| 6502 |
프로프리랜서
|
12년 전 | 5565 | |
| 6501 |
프로프리랜서
|
12년 전 | 2611 | |
| 6500 |
프로프리랜서
|
12년 전 | 3094 | |
| 6499 |
프로프리랜서
|
12년 전 | 1754 | |
| 6498 |
프로프리랜서
|
12년 전 | 1469 | |
| 6497 | 12년 전 | 816 | ||
| 6496 |
yunkiri486
|
12년 전 | 1818 | |
| 6495 | 12년 전 | 924 | ||
| 6494 | 12년 전 | 1501 | ||
| 6493 | 12년 전 | 2770 | ||
| 6492 |
오늘도망했다
|
12년 전 | 2340 | |
| 6491 |
오늘도망했다
|
12년 전 | 1680 | |
| 6490 |
오늘도망했다
|
12년 전 | 6663 | |
| 6489 |
오늘도망했다
|
12년 전 | 2504 | |
| 6488 |
홈피119
|
12년 전 | 711 | |
| 6487 | 12년 전 | 692 | ||
| 6486 | 12년 전 | 1418 | ||
| 6485 | 12년 전 | 2059 | ||
| 6484 | 12년 전 | 909 | ||
| 6483 | 12년 전 | 725 | ||
| 6482 | 12년 전 | 1350 | ||
| 6481 | 12년 전 | 1477 | ||
| 6480 |
Header
|
12년 전 | 697 | |
| 6479 |
|
12년 전 | 1132 | |
| 6478 |
개초보제이
|
12년 전 | 1400 | |
| 6477 | 12년 전 | 805 | ||
| 6476 | 12년 전 | 1082 | ||
| 6475 | 12년 전 | 3691 | ||
| 6474 | 12년 전 | 1433 | ||
| 6473 | 12년 전 | 969 | ||
| 6472 | 12년 전 | 860 | ||
| 6471 |
AMDbest
|
12년 전 | 1211 | |
| 6470 |
jinmuk
|
12년 전 | 1452 | |
| 6469 |
jinmuk
|
12년 전 | 4256 | |
| 6468 |
jinmuk
|
12년 전 | 5587 | |
| 6467 | 12년 전 | 710 | ||
| 6466 |
jinmuk
|
12년 전 | 2288 | |
| 6465 |
jinmuk
|
12년 전 | 6744 | |
| 6464 |
jinmuk
|
12년 전 | 2412 | |
| 6463 |
jinmuk
|
12년 전 | 9338 | |
| 6462 |
희망과열정
|
12년 전 | 544 | |
| 6461 |
Header
|
12년 전 | 732 | |
| 6460 |
희망과열정
|
12년 전 | 1364 | |
| 6459 |
프리랜서개발자
|
12년 전 | 1681 | |
| 6458 | 12년 전 | 1345 | ||
| 6457 |
jinmuk
|
12년 전 | 1955 | |
| 6456 |
jinmuk
|
12년 전 | 2360 | |
| 6455 |
jinmuk
|
12년 전 | 3215 | |
| 6454 |
jinmuk
|
12년 전 | 2182 | |
| 6453 |
jinmuk
|
12년 전 | 2365 | |
| 6452 |
jinmuk
|
12년 전 | 2324 | |
| 6451 |
jinmuk
|
12년 전 | 1619 | |
| 6450 |
jinmuk
|
12년 전 | 1405 | |
| 6449 |
jinmuk
|
12년 전 | 1051 | |
| 6448 |
jinmuk
|
12년 전 | 1252 | |
| 6447 |
jinmuk
|
12년 전 | 2019 | |
| 6446 |
jinmuk
|
12년 전 | 1576 | |
| 6445 |
jinmuk
|
12년 전 | 1270 | |
| 6444 |
jinmuk
|
12년 전 | 2321 | |
| 6443 |
jinmuk
|
12년 전 | 2052 | |
| 6442 |
jinmuk
|
12년 전 | 1898 | |
| 6441 |
jinmuk
|
12년 전 | 1628 | |
| 6440 |
jinmuk
|
12년 전 | 2330 | |
| 6439 |
jinmuk
|
12년 전 | 1146 | |
| 6438 |
wndProc
|
12년 전 | 792 | |
| 6437 | 12년 전 | 416 | ||
| 6436 |
senseme
|
12년 전 | 555 | |
| 6435 | 12년 전 | 1053 | ||
| 6434 | 12년 전 | 2487 | ||
| 6433 | 12년 전 | 2494 | ||
| 6432 | 12년 전 | 1570 | ||
| 6431 |
밥먹고합시다
|
12년 전 | 1199 |
댓글 작성
댓글을 작성하시려면 로그인이 필요합니다.
로그인하기