'Join'에 해당되는 글 2건

  1. 2016.01.03 mysql 여러테이블에 있는 데이터를 들고오기
  2. 2015.12.23 sql join 문

mysql 여러테이블에 있는 데이터를 들고오기

컴퓨터 이야기/SQL 2016. 1. 3. 13:39

하나의 테이블에 원하는 데이터가 모두 없을 경우가 있다. 이럴 때 쓰는 sql 문.


MYSQL

*. 조인(JOIN)은 여러 테이블의 상호 연관관계를 연결하여 결과값을 가져올 때 사용한다.



1. INNER JOIN

  *. INNER JOIN은 조인하는 테이블의 ON 절의 조건이 일치하는 결과만 출력된다.

  EX) SELECT * 

           FROM A_TABLE AS A 

     INNER JOIN B_TABLE AS B  -- 테이블 이름

    ON A_TABLE.COL1 = B_TABLE.COL1; -- 조건문

--A_TABLE.COL1과 B_TABLE.COL1이 일치하는 데이터만 출력된다.


이 때 암묵적으로 A_TABLE 과 B_TABLE 은 연관관계가 있는 테이블이겠다.




'컴퓨터 이야기 > SQL' 카테고리의 다른 글

mysql 최근 데이터 10개만 남기고 지우기  (0) 2016.01.02
mysql 날짜 관련 정리  (0) 2015.12.28
sql sum 으로 합계 구하기  (0) 2015.12.23
sql join 문  (0) 2015.12.23
:

sql join 문

컴퓨터 이야기/SQL 2015. 12. 23. 05:13

샘플 테이블

test1)

+--------+------+

| a      | b    |

+--------+------+

| 금강   |    1 |

| 한강   |    2 |

| 대동강 |    3 |

| 두만강 |    4 |

 


 test2)

+------+--------+

| b    | d      |

+------+--------+

|    1 | 백두산 |

|    2 | 금강산 |

|    5 | 지리산 |

|    6 | 한라산 |

 

 

1) INNER JOIN

Inner join를 이용하여 앞 예제와 동일한 결과를 얻을 수 있는 예는 다음과 같다. 

이는 select 문에서 join에 사용할 컬럼명을 on test1.b=test2.b와 같이 직접 지정해도 된다.

【예제】

mysql> select * from test1 inner join test2 using(b);

+------+------+------+--------+

| a    | b    | b    | d      |

+------+------+------+--------+

| 금강 |    1 |    1 | 백두산 |

| 한강 |    2 |    2 | 금강산 |

+------+------+------+--------+

2 rows in set (0.00 sec)


mysql> select * from test1 inner join test2 on test1.b=test2.b;

+------+------+------+--------+

| a    | b    | b    | d      |

+------+------+------+--------+

| 금강 |    1 |    1 | 백두산 |

| 한강 |    2 |    2 | 금강산 |

+------+------+------+--------+

2 rows in set (0.00 sec)


mysql> select * from test1, test2 where test1.b=test2.b;


mysql>


2) NATURAL JOIN

두 테이블에 같은 이름을 가진 컬럼이 있고, 이 컬럼을 기준으로 join을 하려면 natural join

을 사용한다.

【예제】

mysql> select * from test1 natural join test2;

+------+------+------+--------+

| a    | b    | b    | d      |

+------+------+------+--------+

| 금강 |    1 |    1 | 백두산 |

| 한강 |    2 |    2 | 금강산 |

+------+------+------+--------+

2 rows in set (0.00 sec)


mysql>


3) LEFT OUTER JOIN

test1에는 4개의 레코드가 있는데 where test1.b=test2.b라는 조건 때문에 두 개의 레코드 밖

에 선택되지 않았다. 이때 test2의 b에 test1의 b 값이 존재하지  않더라도 test1의 레코드를

모두 가져오려면 left outer join을 사용한다. left outer join에서 outer는 옵션이므로  생략해

도 된다.

【예제】

mysql> select * from test1 left join test2 using(b);

+--------+------+------+--------+

| a      | b    | b    | d      |

+--------+------+------+--------+

| 금강   |    1 |    1 | 백두산 |

| 한강   |    2 |    2 | 금강산 |

| 대동강 |    3 | NULL | NULL   |

| 두만강 |    4 | NULL | NULL   |

+--------+------+------+--------+

4 rows in set (0.00 sec)


mysql> select * from test1 left join test2 on test1.b=test2.b;

+--------+------+------+--------+

| a      | b    | b    | d      |

+--------+------+------+--------+

| 금강   |    1 |    1 | 백두산 |

| 한강   |    2 |    2 | 금강산 |

| 대동강 |    3 | NULL | NULL   |

| 두만강 |    4 | NULL | NULL   |

+--------+------+------+--------+

4 rows in set (0.01 sec)


mysql>


4) RIGHT OUTER JOIN

 test2에는 4개의 레코드가 있는데, where test1.b=test2.b라는 조건 때문에 2개의 레코드 밖

에 선택되지 않는다. 이때 test1의  b에 test2의 b값이 존재하지 않더라도  test2의 레코드를

모두 가져오려면 right outer join을 사용한다. right outer join에서 outer는 옵션이므로 생략

할 수 있다.

【예제】

mysql> select * from test1 right join test2 on test1.b=test2.b;

+------+------+------+--------+

| a    | b    | b    | d      |

+------+------+------+--------+

| 금강 |    1 |    1 | 백두산 |

| 한강 |    2 |    2 | 금강산 |

| NULL | NULL |    5 | 지리산 |

| NULL | NULL |    6 | 한라산 |

+------+------+------+--------+

4 rows in set (0.00 sec)


mysql>


출처 : http://blog.daum.net/techtip/6671009

: