[mysql] 정렬해서 가져온 놈을 뒤집어야 할 때

php를 예로 설명하자면, mysql_fetch_array($result) 를 하면 가장 위에 있는 놈이 array에 들어가게 된다.

한 마디로, 1,2,3,4,5 순서로 불러왔다면 1,2,3,4,5 순서로 들어오게 된다는 거다. 5부터 불러올 방법이 없다.

당연히, “그럼 DESC로 불러오면 되잖나?” 할 것이다. 맞다. 5개만 갖고 그러면 된다.

그러나 1,3,4,5,6,8,11,13,14,15,16,17,18,21,22 중에서 13 바로 앞의 5개를 오름차순으로 가져오라고 한다면?
SELECT * FROM table WHERE number >= 13-5 AND number < 13 ASC

이렇게 생각할지 모르겠다. 그런데~ 두둥. 위처럼 하면 8,11 고작 두 개만 온다. 그렇다. 숫자가 1씩 증가한다고 보장할 수 없을 때 골때린다.

그럼 5개만 제한해서 가져와 볼까?
SELECT * FROM table WHERE number < 13 ORDER BY number ASC LIMIT 5
와우~ 이렇게 했더니 1,3,4,5,6이 불러와 진다. 그럼 DESC를 쓸까?
SELECT * FROM table WHERE number < 13 ORDER BY number DESC LIMIT 5

그러면 11,8,6,5,4 가 불러와 진다.

여기까지 하고 완전 좌절한 다음에 mysql_fetch_array()의 결과를 array()에 계속 집어넣은 다음 array[4]부터 array[0]까지 차례대로 숫자를 내려서 정보를 받아오느라 뒤지는 줄 알았다.

그런데 너무나, 너무나도! 간단한 해결책이 있었다!!!!
SELECT * 
FROM ( SELECT * FROM table WHERE number < 13 ORDER BY number DESC LIMIT 5) A
ORDER BY no ASC

이렇게 사용하면 되는 것이었다. 셀렉트한 놈들에서 다시 정렬을 하는.(괄호 뒤의 A는 저 괄호에 이름을 붙여 주는 역할을 하는 것 같다. 그거 안 쓰니가 안 되더라.)

역시 정렬 등 자료를 가공하는 것은 sql을 따라올 놈이 없다. 자꾸 프로그래밍단에서 처리하고 싶은 유혹을 느끼곤 하는데 그렇게 하지 말자.

👇 카테고리 글 목록

대표글

댓글 남기기