j

my-sql 서브쿼리^^

서브쿼리(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
|

댓글 5개

여기서 강의를??
기본적으로 생각해도 알 수 있는 기본적인 팁이네요.
감사합니다.^^
참고로 select 내에서 inner select로도 가능합니다.
댓글을 작성하시려면 로그인이 필요합니다.

프로그램

+
제목 글쓴이 날짜 조회
12년 전 조회 1,863
12년 전 조회 1,505
12년 전 조회 5,372
12년 전 조회 1,645
12년 전 조회 1,750
12년 전 조회 1,100
12년 전 조회 2,108
12년 전 조회 1,519
12년 전 조회 3,171
12년 전 조회 2,696
12년 전 조회 2,044
12년 전 조회 2,519
12년 전 조회 1,997
12년 전 조회 1,773
12년 전 조회 1,181
12년 전 조회 1,286
12년 전 조회 5,694
12년 전 조회 2,748
12년 전 조회 3,220
12년 전 조회 1,875
12년 전 조회 1,592
12년 전 조회 953
12년 전 조회 1,967
12년 전 조회 1,076
12년 전 조회 1,641
12년 전 조회 2,900
12년 전 조회 2,473
12년 전 조회 1,820
12년 전 조회 6,799
12년 전 조회 2,632
12년 전 조회 848
12년 전 조회 799
12년 전 조회 1,547
12년 전 조회 2,211
12년 전 조회 1,021
12년 전 조회 839
12년 전 조회 1,474
12년 전 조회 1,605
12년 전 조회 842
12년 전 조회 1,265
12년 전 조회 1,543
12년 전 조회 930
12년 전 조회 1,221
12년 전 조회 3,797
12년 전 조회 1,565
12년 전 조회 1,095
12년 전 조회 983
12년 전 조회 1,358
12년 전 조회 1,598
12년 전 조회 4,382
12년 전 조회 5,714
12년 전 조회 834
12년 전 조회 2,409
12년 전 조회 6,874
12년 전 조회 2,539
12년 전 조회 9,475
12년 전 조회 674
12년 전 조회 864
12년 전 조회 1,491
12년 전 조회 1,805
12년 전 조회 1,467
12년 전 조회 2,070
12년 전 조회 2,479
12년 전 조회 3,350
12년 전 조회 2,314
12년 전 조회 2,487
12년 전 조회 2,454
12년 전 조회 1,738
12년 전 조회 1,540
12년 전 조회 1,184
12년 전 조회 1,367
12년 전 조회 2,166
12년 전 조회 1,718
12년 전 조회 1,412
12년 전 조회 2,440
12년 전 조회 2,191
12년 전 조회 2,031
12년 전 조회 1,773
12년 전 조회 2,456
12년 전 조회 1,270
12년 전 조회 927
12년 전 조회 538
12년 전 조회 678
12년 전 조회 1,198
12년 전 조회 2,618
12년 전 조회 2,621
12년 전 조회 1,695
12년 전 조회 1,326
12년 전 조회 1,107
12년 전 조회 9,235
12년 전 조회 742
12년 전 조회 1,700
12년 전 조회 1,295
12년 전 조회 1,741
12년 전 조회 1,946
12년 전 조회 1,133
12년 전 조회 1,708
12년 전 조회 2,366
12년 전 조회 1,485
12년 전 조회 1,426
🐛 버그신고