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
번호 | 분류 | 제목 | 글쓴이 | 날짜 | 조회 수 |
---|---|---|---|---|---|
1069 | Develop |
[c] RSA 암호화 구현(gmp 라이브러리 활용)
![]() |
hooni | 2016.10.03 | 2751 |
1068 | Develop | [php] 한글 문자열 자르기 (utf-8) | hooni | 2015.11.10 | 2786 |
1067 | Develop | [android] Android N requires the IDE to be running with Java 1.8 or later 오류 | hooni | 2016.08.30 | 2788 |
1066 | Develop | [android] 레이아웃 사이즈 변경 (동적; programmatically) | hooni | 2016.11.07 | 2792 |
1065 | Develop | [ios] 코코아 프로그래밍의 네이밍 룰(명명 규칙) | hooni | 2017.05.11 | 2800 |
1064 | PPT |
삼성페이(Samsung Pay) 구조
![]() |
hooni | 2016.09.09 | 2802 |
1063 | Develop | [kotlin] 코틀린 안드로이드 앱 버전/빌드 정보 | hooni | 2020.12.15 | 2815 |
1062 | Develop | [ios] @property의 속성 (strong, weak, copy) 사용 경우 | hooni | 2014.08.08 | 2816 |
1061 | Develop |
캘리포니아 운전면허 족보
![]() |
hooni | 2017.06.12 | 2826 |
1060 | PPT |
[ppt] Equation Solving 발표 자료 (@AjaxUI랩 밋업데이 2012.02.28)
![]() |
hooni | 2015.07.22 | 2835 |
1059 | Develop | [ios] 상위 ViewController 가져오기 | hooni | 2015.10.12 | 2848 |
1058 | Develop |
[c#] 툴바 현재 욜심히 만들고 있는거.. 백업용.. ㅋㅋ
![]() |
hooni | 2013.04.23 | 2852 |