Contents

조회 수 2988 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
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


?

  1. [mysql] MySQL 데이터베이스 추가 및 사용자 추가

  2. [oracle] Oracle 사용자 추가 절차

  3. [mysql] MySQL 백업 및 복구

  4. [mysql] MySql DB/테이블 사이즈 확인을 위한 쿼리

  5. SQL JOIN 정리 (Inner Join & Outer Join)

  6. [mysql] MacOS에 MySQL 설치, 설정, 암호 재설정

  7. [mysql] ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.

  8. [mysql] MySQL 한글 깨짐 현상 해결하기(UTF8)

  9. [mysql] 중복데이터 삭제하는 초간단 쿼리

  10. [mysql] 쿼리 실행시 ERROR 1366 (HY000) : incorrect string value : for column

  11. [mysql] CPU 점유율이 높을 때 확인할 내용

  12. [mysql] MySql 에서 정렬 후 그룹 하는 방법

Board Pagination Prev 1 2 Next
/ 2