Database
2015.05.07 23:16
[mysql] MySql 에서 정렬 후 그룹 하는 방법
조회 수 3006 댓글 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
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
1065 | System/OS | [linux] Oracle8.1.6, Mysql+PHP+Zend Optimizer+APACHE+Tomcat(jsp,servlet)+IMAP+gd | hooni | 2003.04.23 | 32444 |
1064 | System/OS | [linux] 특수문자 환경 설정(stty) | hooni | 2003.04.23 | 15267 |
1063 | System/OS | [linux] 메타(기호)문자의 의미와 사용 | hooni | 2003.04.23 | 16374 |
1062 | System/OS | [linux] 프로세스 상태확인(ps) | hooni | 2003.04.23 | 12695 |
1061 | System/OS | [linux] 종료와 종료코드 확인(환경변수에서) | hooni | 2003.04.23 | 15532 |
1060 | System/OS | [linux] 셀 스크립트 if, for, case in.. | hooni | 2003.04.23 | 13678 |
1059 | System/OS | [linux] 스케쥴링 순서(nice) 변경하기 | hooni | 2003.04.23 | 12528 |
1058 | System/OS | [linux] 기존 환경설정 저장하면서 커널 컴파일.. | hooni | 2003.04.23 | 13450 |
1057 | System/OS | [linux] Proftpd 설치 가이드 | hooni | 2003.04.23 | 13013 |
1056 | Develop | [c] 간단한 자료구조(stack, queue, linked list) 구현 소스 6 | hooni | 2003.04.23 | 10098 |
1055 | Develop | [c] 파일입출력, 링크리스트(linked list)를 이용한 주소록(도스용) 소스코드 1 | hooni | 2003.04.23 | 11133 |
1054 | Develop | [c] 테트리스(Tetris) 게임(도스용) 소스코드 | hooni | 2003.04.23 | 11459 |