order by 이후 rownum이 의도와 다르게 찍힙니다.

by 바보똥개 posted Apr 14, 2023


* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.

OS
Window7 32bit, Linux 64bit 등
CUBRID Ver.
[cubrid_rel] 수행 결과
CUBRID TOOL Ver.
[도움말]-[버전정보] 확인
응용 환경(API)
java, php, odbc 등 입력


* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.

 

에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


-------------- 아래에 질문 사항을 기입해 주세요. ------------------------------------------------------------------------
 

안녕하세요. 현재 공공기관쪽 개발을 진행하고 있습니다.

 

현재 개발서버가 내/외부 1대씩, 운영서버 해서 총 3군데에 설치가 되어있으며

각각 db는 

11.0.9.0331 (개발1이라 하겠습니다) - 윈도우

10.2.7.8896 (개발2라 하겠습니다) - 윈도우

11.2.2.0705 (운영) - RHEL

 

문제가 되는건 페이징 처리를 하며 리스트를 가져오는 경우인데,

 

현재 쿼리 형태는 아래와 같습니다.

 

SELECT * FROM (SELECT ROWNUM rn, TB.* FROM (

 

// SELECT 어쩌구저쩌구

// WHERE 어쩌구저쩌구

// ORDER BY 어쩌구저쩌구

 

) TB ) Z WHERE RN BETWEEN 1 AND 10  ;

 

BETWEEN 값은 페이지에 따라 1 AND 10, 11 AND 20 요런식으로 바뀌고 있고요.

 

ALIAS TB 까지는 원하는 결과가 출력되며, order by도 의도한대로 표시가 됩니다.

근데 운영 db에서만 그 이후 rownum을 붙이면 order by로 소팅했던 순서가 깨져서 나옵니다.

order by를 asc, desc 여부에 따라서도 rownum이 다르게 붙어서 나오더군요.

똑같은 쿼리이지만 개발 db 2개는 문제가 없습니다.

 

rownum 형태를 사용하지 않고 limit 0, 10 같이 가면 이건 문제없이 의도대로 결과가 출력됩니다.

 

혹시 jdbc 드라이버 문제인가 하고 테스트를 해봤지만 결과는 동일했습니다.

이곳 문의글에 답변을 봐도 11버전부터는 드라이버가 db 버전별로 릴리즈가 되지 않고 기존것을 써도 상관없다는 글을 본것 같습니다.

 

개발db 2개는 기본설치로 진행했고, 운영db는 제가 설치하지 않아 무슨 설정이 따로 들어간건지는 알수 없습니다. 

db가 문제인지, 다른 어떤 설정을 바꾸어야 하는지 감이 잡히지 않아 문의글 드립니다.