Database
2015.05.07 23:16
[mysql] MySql 에서 정렬 후 그룹 하는 방법
Views 3149 Comment 0
MySQL 쿼리 작성 중 정렬 후 group by 를 할 수 없음을 알게 되고 좌절..
카운터를 만들다가 URL로 group by 해야 할 일이 생겼는데, 최근 접속 순으로 정렬을 할 필요가 있었다.
정렬 후 그룹화.
아무 생각없이 손 가는대로 뭐 되겠지 라는 생각으로 쿼리를 만들었더니,
SELECT * FROM tableName GROUP BY tableName.url ORDER BY tableName.no DESC
실행해보니 오류 없이 데이터가 잘 나왔다.
하지만 데이터가 좀 쌓이고 보니 최신 URL이 아닌 맨 처음 URL에 대한 레코드 기준으로 group by 되고 있었음 ㅠㅠ
원하는 프로세스는 [정렬 => 그룹화] 인데. 동작하는 프로세스는 [그룹화 => 정렬] 이었다.
그래서 이렇게 바꿨더니..
SELECT * FROM tableName ORDER BY tableName.no DESC GROUP BY tableName.url
제길!!! 에러다 ㅠㅠ;;
이제, 해결 방안은 2가지.. 우선!
[1안] 테이블 구조를 날짜 역순으로 재설계 해서 order by 없이 정렬~
[2안] 서브쿼리 난발
테이블과 프로그램을 바꾸는거 보다 서브쿼리 난발로 처리하기로 했다.
SELECT * FROM ( SELECT * FROM tableName ORDER BY tableName.no ) AS aliasTable GROUP BY aliasTable.url
No. | Category | Subject | Author | Date | Views |
---|---|---|---|---|---|
23 | Database | [mysql] 접속과 테이블 생성 간단한 설명.. | hooni | 2003.04.23 | 18747 |
22 | Database | [sql] 간단한 SQL 문법 정리 | hooni | 2003.04.23 | 12628 |
21 | Database | [mysql] 쓰레드가 계속 쌓이기 시작하고 사라지지 않을때.. | hooni | 2003.04.23 | 12858 |
20 | Database | [mysql] DB->Text, Text->DB 변환 | hooni | 2003.04.23 | 12218 |
19 | Database | [mysql] error while loading shared libraries: libmysqlclient.so.10: | hooni | 2003.04.23 | 12735 |
18 | Database | [mysql] 쿼리 로그 저장 매뉴얼 | hooni | 2013.04.23 | 15371 |
17 | Database | [mysql] 루트 암호 초기화 | hooni | 2013.04.23 | 11123 |
16 | Database | [sql] 간단한 통계 서브쿼리 예제.. | hooni | 2013.04.23 | 15176 |
15 | Database | [oracle] SQL문 실행 방법 3가지 | hooni | 2013.12.19 | 12197 |
14 | Database | [sql] 쿼리로 문자열 검색해서 일괄 치환하기 | hooni | 2014.02.13 | 10071 |
13 | Database | [sql] 한눈에 보이는 Join | hooni | 2014.02.19 | 8553 |
» | Database | [mysql] MySql 에서 정렬 후 그룹 하는 방법 | hooni | 2015.05.07 | 3149 |