[SQL 기초] Outer Join

[SQL 기초] Outer Join

주요 사용 예시: 누락된 데이터 찾기

<고객 정보>
고객, 주문번호
홍길동, 주문2
강감찬, 주문1
세종대왕, NULL

<주문 정보>
주문번호, 메뉴
주문1, 돈가스
주문2, 짬뽕
주문3, NULL

LEFT OUTER JOIN

고객 데이터를 모두 가져오고 주문이 없으면 비어있는 값으로 가져오기

SELECT A.고객, B.메뉴
FROM 고객정보 A, 주문정보 B
WHERE A.주문번호(+) = B.주문번호 -- 오라클 DB SQL

SELECT 고객정보.고객, 주문정보.메뉴
FROM 고객정보
LEFT OUTER JOIN 주문정보
ON 고객정보.주문번호 = 주문정보.주문번호 -- 표준 SQL

RIGHT OUTER JOIN

주문 데이터를 모두 가져오고 고객 데이터가 없으면 비어있는 값으로 가져오기

SELECT A.고객, B.메뉴
FROM 고객정보 A, 주문정보 B
WHERE A.주문번호 = B.주문번호(+)   -- 오라클 DB SQL

SELECT 주문정보.메뉴, 고객정보.고객
FROM 주문정보
RIGHT OUTER JOIN 고객정보
ON 주문정보.주문번호 = 고객정보.주문번호 -- 표준 SQL

FULL OUTER JOIN

사용을 권장하지 않음. 성능 이슈

Read more

쉬어가며2

쉬어가며2

개발 일만 하다 보면 눈앞의 코드에만 집중하게 된다. 오늘은 조금 다른 이야기를 해볼까 한다. 바로 주식에 대한 이야기다. 왜 주식을 해야 하는가? 주식을 시작하면 자연스럽게 질문이 많아진다. "왜 이 회사는 영업이익이 늘었는데 주가는 떨어졌을까?" "PER이 낮은데 왜 아무도 사지 않을까?" 재무제표를 읽고, 뉴스를 찾아보고, 시장의 흐름을 추적하다 보면 세상을 보는

By Jeonggil
쉬어가며

쉬어가며

개발 일만 하다 보면 때로는 잠시 멈춰서 주변을 둘러보는 것도 중요하다. 오늘은 오래전에 다녔던 병원에서의 일을 가볍게 풀어볼까 한다. 고객이 병원에 방문하고, 그것이 수익으로 이어지기까지. 그 안에는 생각보다 훨씬 많은 전략과 기술, 그리고 사람들의 노력이 숨어있다. 1. 들어가며 오래전 다녔던 한 병원에서의 일이다. 당시 나는 "의료 IT"라는 낯선 도메인에

By Jeonggil