Skip to Content
Go Back
안형우

안녕하세요. 14년차 풀스택 웹개발자 안형우입니다. 이 블로그에서는 WordPress, PHP, CSS, 사용성, 리눅스 서버 등 풀스택 웹개발에서 마주하는 다양한 문제 상황과 해결책, 필요한 개념들을 다룹니다. 👉 소개


작업물

📌 워드프레스, 답답한 빌더와 플러그인 대신 시원하게 커스터마징하기(강의) 2023-01-15
📌 아무도 말하지 않는 PHP의 좋은 점 2018-10-13
📌 유지보수하기 쉬운 CSS 전략(슬라이드) 2016-12-20
📌 워드프레스 테마에서 템플릿 파일 매칭 순서 2013-05-12
📌 [번역] CSS 코드 냄새 2013-01-01

[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을 따라올 놈이 없다. 자꾸 프로그래밍단에서 처리하고 싶은 유혹을 느끼곤 하는데 그렇게 하지 말자.

안녕하세요. 14년차 풀스택 웹개발자 안형우입니다. 이 블로그에서는 WordPress, PHP, CSS, 사용성, 리눅스 서버 등 풀스택 웹개발에서 마주하는 다양한 문제 상황과 해결책, 필요한 개념들을 다룹니다. 👉 소개


작업물

답글 남기기

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다