메뉴 건너뛰기

?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
보통 mysql에서는 외래키를 잡아놓고 두 외래키가 같은 것들로 조인을 해서 쓰는 방식이 많다. 필자도 보통 그런식으로만 해왔기 때문에 지금부터 쓸 포스트의 내용을 쓸일이 여태껏 거이 없었다. 하지만 종종 쓰다보니, 아무래도 이건 나중에 쓸때 또 찾을거 같은 내용 같기에 이렇게 글을 써본다.

일단 두 테이블 ids와 list가 있다고 하자.

mysql> select * from ids;
+-----+------+------+
| sid | year | id   |
+-----+------+------+
|   1 | 2007 | A    |
|   2 | 2008 | B    |
|   3 | 2010 | C    |
|   4 | NULL | D    |
+-----+------+------+
4 rows in set (0.00 sec)

mysql> select * from list;
+------+------+-------+
| year | id   | fee   |
+------+------+-------+
| 2008 | A    | 10000 |
| 2008 | A    | 15000 |
| 2008 | B    | 20000 |
| 2009 | B    | 10000 |
| 2009 | A    | 15000 |
| 2010 | C    | 10000 |
| 2010 | D    | 20000 |
+------+------+-------+
7 rows in set (0.00 sec)

위 두 테이블을 조인해서 아이디별로 자신의 year에 해당하는 list의 목록을 뽑아 오려고 한다면,

mysql> select * from ids left join list on ids.id = list.id where ids.year = list.year;
+-----+------+------+------+------+-------+
| sid | year | id   | year | id   | fee   |
+-----+------+------+------+------+-------+
|   2 | 2008 | B    | 2008 | B    | 20000 |
|   3 | 2010 | C    | 2010 | C    | 10000 |
+-----+------+------+------+------+-------+
2 rows in set (0.00 sec)

위와 같이 뽑아 올수 있다. 

위의 결과에서 A는 ids 테이블에 year해당하는 list의 값이 없기에 뽑아올수 없는데, 이런 A와 같은 목록을 뽑아오려면 not exists나 not in를 쓰면 된다.

mysql> select * from ids where not exists (select 1 from list where ids.id = list.id and ids.year = list.year );
+-----+------+------+
| sid | year | id   |
+-----+------+------+
|   1 | 2007 | A    |
|   4 | NULL | D    |
+-----+------+------+
2 rows in set (0.00 sec)

mysql> select * from ids where id not in (select id from list where ids.id = list.id and ids.year = list.year );
+-----+------+------+
| sid | year | id   |
+-----+------+------+
|   1 | 2007 | A    |
|   4 | NULL | D    |
+-----+------+------+
2 rows in set (0.00 sec)

하지만 여기서 한가지 알아둘것이 있는데, 위의 조건은 ids의 year과 list의 year이 같지 않은 id를 찾는것이다. 그렇다면, 아래와 같은 조건으로 not in을 쓸 수 있다.

mysql> select * from ids where year not in (select year from list where ids.id = list.id );
+-----+------+------+
| sid | year | id   |
+-----+------+------+
|   1 | 2007 | A    |
+-----+------+------+
1 row in set (0.00 sec)

바로 여기서 차이점이 발생한다. 조건만으로 따져볼때는 위의 조건이 틀려 보이진 않는다.
D의 year를 보면, ids에는 NULL로 되어 있고 list에는 2010로 되어 있기 때문에 NULL과 2010은 다르기 때문이다.
하지만, not in은 조건으로 들어가는 값이 NULL인 것을 결과에서 제외시켜 버린다. 

뭐 이건 이거대로 잘 활용한다면 괜찮은 팁이 될 수 있으나, not in으로 NULL까지 나오게 하고 싶다면 조건을 잘 주어야 할 것이다.

  1. [MySQL] 백업 및 복구

    Date2017.04.12 Views5392
    Read More
  2. [mysql,mariaDB] 컬럼 암호화, 복호화

    Date2020.11.25 Views773
    Read More
  3. UPDATE ~ CASE 문을 사용한 조건별 업데이트

    Date2020.07.28 Views1396
    Read More
  4. Union 사용법. 여러 테이블의 같은 값을 한번 쿼리로 추출하기

    Date2017.11.21 Views3918
    Read More
  5. SQL 고급

    Date2017.12.22 Views6035
    Read More
  6. order by field 와 union, 원하는 대로 정렬 하기

    Date2021.03.26 Views768
    Read More
  7. no exists, not in 을 이용한 조건에 만족하지 않는 것들 구하기, 둘의 차이점

    Date2021.03.26 Views125
    Read More
  8. MySQL의 alter table 명령어 모음

    Date2017.04.12 Views5105
    Read More
  9. MySQL에서 원격 IP 접속 허용하기

    Date2017.04.12 Views5621
    Read More
  10. MySQL에서 사용자 권한 주기 (grant 명령어)

    Date2017.04.12 Views5885
    Read More
  11. MySQL〃오라클의 nextval을 MySQL에서 사용하기

    Date2018.07.24 Views3864
    Read More
  12. mysqlbinlog (mysql 백업, 로그남기기)

    Date2021.03.26 Views201
    Read More
  13. MySQL/MariaDB 백업 & 복원 - mysqldump

    Date2015.08.07 Views7384
    Read More
  14. mysql-bin(binary log)파일 정리 및 삭제

    Date2023.01.12 Views117
    Read More
  15. mysql-bin 로그를 SQL 문으로 변환한는 방법

    Date2018.07.18 Views1672
    Read More
  16. mysql(union,join)

    Date2017.11.16 Views3837
    Read More
  17. mysql(exists, not exists)

    Date2017.11.16 Views4090
    Read More
  18. MYSQL 프로시져 PROCEDURE

    Date2021.03.27 Views197
    Read More
  19. mysql 포트 바꾸기, 외부에서 접속하기

    Date2021.03.26 Views5078
    Read More
  20. MySQL 파티션 개요

    Date2017.12.22 Views4150
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 Next
/ 7

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved