일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 자바
- IPO
- 7월 공모주 청약 일정
- html
- 코드이그나이터
- 맥
- Oracle
- Stock ipo
- php
- linux
- 공모주
- 오라클
- jquery
- Eclipse
- SQL
- 주식 청약
- 주식 청약 일정
- 리눅스
- MYSQL
- 자바스크립트
- codeigniter
- 6월 공모주 청약 일정
- 공모주 청약
- java
- 제이쿼리
- JavaScript
- css
- 주식
- 공모주 청약 일정
- Stock
- Today
- Total
개발자의 끄적끄적
[mysql] GROUP BY와 HAVING [펌] 본문
[mysql] GROUP BY와 HAVING [펌]
GROUP BY와 HAVING은 다음과 같은 syntax를 따릅니다.
SELECT column-names FROM table-name WHERE condition GROUP BY column-names HAVING condition
GROUP BY
MySQL에서의 GROUP BY는 특정 컬럼 이름을 지정(column-names)해주면 그 컬럼의 UNIQUE한 값에 따라서 데이터를 그룹 짓고, 중복된 열은 제거됩니다.
GROUP BY는 보통 집합 함수(aggregate function, [AVG, SUM, COUNT 등을 말합니다])와 같이 쓰이며, 다음과 같은 형태를 지닙니다.
SELECT c1, c2,..., cn, aggregate_function(ci) FROM table WHERE where_conditions GROUP BY c1 , c2,...,cn;
예를 들어, 다음과 같은 order 테이블이 있다고 합시다.
아래의 SQL 구문을 실행한 결과(status 별로 그룹지어서 각각의 갯수를 센 결과로 테이블을 만듭니다),
SELECT status, COUNT(*) FROM orders GROUP BY status;
결과는 다음과 같습니다.
HAVING
HAVING은 간단하게 생각해서 GROUP BY한 결과에 조건을 붙이고 싶을때, 즉 GROUP BY의 WHERE 절과도 같다고 볼 수 있습니다.
위의 예제에서, 각각 status의 총 갯수(COUNT)가 4이상인 경우를 예제로 보여드리겠습니다.
SELECT status, COUNT(*) FROM orders GROUP BY status HAVING COUNT(*) > 4;
결과는 다음과 같습니다.
'개발 > sql' 카테고리의 다른 글
[sql] 계층형 트리구조 쿼리 [펌] (0) | 2020.06.04 |
---|---|
[MySQL] GROUP BY , HAVING [펌] (0) | 2020.06.04 |
[mysql] ifnull 사용법 (0) | 2020.06.03 |
[mysql] Cannot add foreign key constraint [펌] (0) | 2020.05.31 |
[mysql] linux(CentOS 7)에서 MySQL log 확인방법 (0) | 2020.05.30 |