일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
- mathemetica
- is_array
- android studio
- Get
- solution
- 단축키
- 월별 카운트
- PORTG
- array
- 현재언어
- unalias
- Post
- php
- 하이퍼 터미널
- halliday
- Java
- 0x
- selectc
- SQL
- function
- 점점변하는값
- 파일존재
- Avr
- C++
- application.mk
- Call
- mysql
- Join
- 강좌
- cocos2d-x
- Today
- Total
코딩도사의 코드정리
sql join 문 본문
샘플 테이블
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
'컴퓨터 이야기 > SQL' 카테고리의 다른 글
mysql 여러테이블에 있는 데이터를 들고오기 (0) | 2016.01.03 |
---|---|
mysql 최근 데이터 10개만 남기고 지우기 (0) | 2016.01.02 |
mysql 날짜 관련 정리 (0) | 2015.12.28 |
sql sum 으로 합계 구하기 (0) | 2015.12.23 |