4. DB 조작해보기(sp_help과 같은코드, JOIN, *JOIN에 JOIN example)
MSSQL 의 sp_help(alt+F1)과 같은 기능은 존재하지 않는다.
SELECT *
FROM information_schema.columns
WHERE table_schema = 'your_schema'; --public
AND table_name = 'your_table'; --customers, purchases, items
위와 같은 구분으로 실행할 순 있다.
join
join은 python에서 set과 마찬가지다.유니크한 요소들이 순서가 없다
.
그러나, 이들은 교집합/ 합집합 / 여집합 계산이 가능하다는 장점이 있다.SELECT * FROM 테이블1의 ON조건
대해서 INNER JOIN 테이블2의 ON조건
을 테이블1에서부터 하나씩 검사
하면서 교집합 있는 것들을 붙혀서 row단위로 나타낸다.
INNER JOIN
=교집합
1) SELECT * FROM 테이블1(Customers)로 다 보이게 할 건데,
2) INNER JOIN 테이블2(Orders) 을 붙힐건데,
3) ON 테이블1.id = 테이블2.id 로 교집합을 row를 붙힌다. 나는 테이블1의 ON인 id 1에 대해서 테이블2가 걸리는 것들을 검사해서 하나씩 붙힌다고 생각했다. 1-jose에 대해서, orders테이블에는 customer_id가 1인데 3개가 있으니 3개가 연달아 붙을 것이다.
왼쪽테이블의 2는 걸리는게 없다.
왼쪽테이블의 3-anna와 걸리는게 1개 있으니 붙힌다LEFT JOIN
역시 인기가 많은 JOIN으로서,
LEFT에 있는 테이블1은 모두 살리면서, 교집합을 검사하는데, 왼쪽테이블1으로 검사시교집합이 없어도 BLANK(MSSQL : NULL)
로 나타내면서 테이블1을 다 살린다.
1) 테이블1을 기준으로 검사하는데 걸리는게 있으면 나타낸다.2) 만약 걸리는게 없어도, 테이블1은 살리면서 테이블2는 NULL로 나타낸다.
RIGHT JOIN
은 LEFT JOIN과 반대로, 오른쪽에서 검사를 시작하면서, 교집합이 없어도 오른쪽은 살리면 된다
FULL JOIN
은 교집합 + 여집합까지 다나타내는 것이다.LEFT JOIN과 RIGHT JOIN을 모두 생각
해야한다.왼1 -> 오1 -> 왼2 -> 오2 -> 순으로 하나씩 교집합과 여집합을 챙겨준다.
1) 일단 나는 왼쪽테이블1에 대해 교집합을 찾고,오른쪽테이블1은 교집합으로 물려갔으니 생각안한다.
2) 왼쪽테이블2에 대해서는 교집합이 없으니 여집합으로서 나타낸다.
3) 오른쪽테이블2에 대해서도 교집합이 없으니 여집합으로 챙긴다.
4) 왼3에서는 교집합이 있으니 교집합으로 챙긴다.
5)
오3은 이미 왼1로서 교집합으로 잡혀갔다.
6) 왼4는 여집합으로서 챙긴다.
7) 오4는 이미 교집합으로 잡혀갔다.
join examples
SELECT * FROM purchases; SELECT * FROM items; SELECT * FROM customers; -- 1) item들 중에 구매한 items 목록을 원하는 경우 SELECT * FROM items JOIN purchases ON items.id = purchases.id; -- left조인을 쓴다면, 구매하지 않은 아이템도 블랭크로 붙는다. SELECT * FROM items LEFT JOIN purchases ON items.id = purchases.id; -- 2) 이제 어느 고객이 어느 아이템을 샀는지 join해보자. SELECT * FROM customers JOIN purchases ON customers.id = purchases.customer_id; --left join SELECT * FROM customers LEFT JOIN purchases ON customers.id = purchases.customer_id; -- 고객 중에 구매를 한 고객 join데이터 중 이름만 select하기 SELECT customers.first\_name, customers.last_name FROM customers JOIN purchases ON customers.id = purchases.customer_id; -- 3) ***3개 테이블 한꺼번에 join해보기*** ---- (1) items중에 구매한 것들만 item만 나오도록 inner join한다. SELECT * FROM items INNER JOIN purchases ON items.id = purchases.item_id ---- (2) 여기서 보이는 customer\_id로 고객들을 연결할 수 있을 것이다. *** JOIN한것에 바로 JOIN을 해버린다. SELECT * FROM items INNER JOIN purchases ON items.id = purchases.item_id INNER JOIN customers ON purchases.customer_id = customers.id ---- (3) 필요한 칼럼만 챙겨보자. SELECT customers.first_name, customers.last_name, items.name, items.price FROM items INNER JOIN purchases ON items.id = purchases.item_id INNER JOIN customers ON purchases.customer\_id = customers.id
'한의대 생활 > └ PostgreSQL' 카테고리의 다른 글
CREAT TABLE*(primary key, references) and INSERT INTO (0) | 2019.01.29 |
---|---|
JOIN*(3개 테이블) and GROUP BY*(보이지않더라도 key칼럼으로) and ORDER BY (0) | 2019.01.29 |
3. DB 조작해보기(UPDATE, DELETE, LIKE %_FILTERING*) (0) | 2019.01.23 |
2. 쿼리창 및 간단한 DB조작(SELECT, WHERE, LIMIT*) (1) | 2019.01.23 |
1. PostgreSQL 다운 및 설치 / pgAdmin3 실행 해보기 (0) | 2019.01.23 |