Database
2015.05.07 23:16
[mysql] MySql 에서 정렬 후 그룹 하는 방법
조회 수 5107 댓글 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
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
277 | Develop | [ios] Swift 4 Singleton inheritance | hooni | 2018.10.31 | 5938 |
276 | System/OS | How to Setup an Email Server on CentOS 7 | hooni | 2018.04.05 | 5919 |
275 | Etc |
아이폰의 터치스크린 정확도
![]() |
hooni | 2015.04.01 | 5870 |
274 | Develop | [ios] UITableView 특정 Row만 Update | hooni | 2014.04.08 | 5799 |
273 | Database | [mysql] ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement. | hooni | 2017.12.15 | 5742 |
272 | Develop |
[php] Connect to Firebase Console in Laravel
![]() |
hooni | 2018.05.09 | 5736 |
271 | Etc |
영어. 불규칙 동사 정리
![]() |
hooni | 2017.10.04 | 5691 |
270 | Develop |
[ios] 웹뷰 history.back() ㅋㄷ
![]() |
hooni | 2016.06.27 | 5674 |
269 | System/OS |
How to Install and Use wget on Mac
![]() |
hooni | 2020.09.03 | 5596 |
268 | Develop | [js] show/hide 이벤트 감시 (Observing show/hide event) | hooni | 2021.02.03 | 5570 |
267 | Develop |
[php][laravel] 라라벨 개발환경 세팅하기 (Mac, Window)
2 ![]() |
hooni | 2017.12.15 | 5556 |
266 | Develop |
[js] Javascript로 만든 포트리스 (2010)
5 ![]() |
hooni | 2017.03.03 | 5495 |