이번건은..쪼매 수월하다...왜냐..바로... 그... 자격증 때문이다..
6개월을 시달리게 했던 그.... 기사 그거 있다 여튼...
뿐만 아니라, 뭐 다른 부분들도 있겄지..
나는 잘 되고 있다.
구조화된 데이터는 하나의 테이블로 표현할 수 있다.
사전에 정의된 테이블을 relation이라고도 부르기 때문에, 테이블을 사용하는 데이터베이스를 관계형 데이터베이스(Relational database)라고 한다.
1:1 관계
1:N 관계
N:M 관계
*self referencing 관계
부산 돼지내장국밥 먹고싶다. 고향가고싶다.
데이터를 조회할 때, 그룹으로 묶어서 조회한다.
SELECT * FROM customers;
▲ customers 테이블의 모든 레코드를 조회
위의 쿼리를 주(state:상태)에 따라 그룹으로 묶어 표현할 수 있다.
SELECT * FROM customers
GROUP BY State;
▲ customers 테이블의 모든 레코드를 State에 따라 그룹화
HAVING은 GROUP BY로 조회한 결과를 필터링할 수 있다.
SELECT CustomerId, AVG(Total)
FROM invoices
GROUP BY CustomerId
HAVING AVG(Total) > 6.00
▲ invoices 테이블을 CustomerId로 그룹화하고 그 평균이 6을 초과한 결과를 조회
해당 쿼리는 모든 고객의 주문서에서 가격의 평균을 구한 뒤에, 평균이 6.00을 넘는 결과만 조회하는 쿼리를 예시로 한 것이다.
GROUP BY로 그룹을 지은 결과에 필터를 적용할 때, HAVING을 사용할 수 있다.
HAVING은 WHERE과 적용하는 방식이 다름
HAVAING은 그룹화한 결과에 대한 필터이고, WHERE은 저장된 레코드를 필터링한다.
따라서 그룹화 전에 데이터를 필터해야 한다면 WHERE을 사용함.
COUNT 함수는 레코드의 갯수를 헤아릴 때 사용.
SELECT *, COUNT(*) FROM customers
GROUP BY State;
▲ 모든 레코드에 대한 COUNT 함수 예시
위의 쿼리를 실행하면, 각 그룹의 첫번쨰 레코드와 각 그룹의 레코드 갯수를 집계하여 리턴한다.
아래와 같이 변경시 그룹으로 묶인 결과의 레코드 갯수도 확인 가능
SELECT State, COUNT(*) FROM customers
GROUP BY State;
▲ 각 State에 해당하는 레코드의 개수를 확인하는 COUNT 함수 예시
SUM 함수는 레코드의 합을 리턴한다.
SELECT InvoiceId, SUM(UntiPrice)
FROM invoice_items
GROUP BY InvoiceId;
▲ SUM 함수 사용 예시
위 쿼리는 invoice_items라는 테이블에서 InvoiceId 필드를 기준으로 그룹하고, UnitPrice 필드 값의 합을 구한다.
AVG 함수는 레코드의 평균 값을 계산하는 함수.
SELECT TrackId, AVG(UnitPrice)
FROM invoice_items
GROUP BY TrackId;
▲ AVG 함수 사용 예시
MAX는 최댓값을, MIN은 최솟값을 리턴.
SELECT CustomerId MIN(Total)
FROM invoices
GROUP BY CustomerId
▲ MIN 함수 사용 예시
위 쿼리에서 MIN을 MAX로 변경하면, 각 고객이 지불한 최대금액을 리턴한다.
데이터를 조회하는 SELECT 문은 정해진 순서대로 동작한다.
SELECT CustomerId, AVG(Total)
FROM invoices
WHERE CustomerId >= 10
GROUP BY CustomerId
HAVING SUM(Total) >= 30
ORDER BY 2
▲ SELECT 문의 실행 순서
위 쿼리의 실행 순서는 다음과 같다.
1. FROM invoices
: invoices 테이블에 접근을 한다.
2. WHERE CustomerId >= 10
: CustomerId 필드가 10 이상인 레코드를 조회
3. GROUP BY CustomerId
: CustomerId를 기준으로 그룹화한다.
4. HAVING SUM(Total) >= 30
: Total 필드의 총합이 30 이상인 결과들만 필터링함
5. SELECT CustomerId, AVG(Total)
: 조회된 결과에서 CustomerId 필드와 Total 필드의 평균값을 구한다.
6. ORDER BY 2
: AVG(Total)
필드를 기준으로 오름차순 정렬한 결과를 리턴.