Background Image

FORUM

조회 수 4605 추천 수 0 댓글 2
?

단축키

Prev이전 문서

Next다음 문서

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


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

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가 문제인지, 다른 어떤 설정을 바꾸어야 하는지 감이 잡히지 않아 문의글 드립니다.

 

 

  • ?
    주영진 2023.04.14 15:17

    안녕하세요.

     

    11.2 버전에서 인라인 뷰에 대한 뷰 머징을 개선하면서 발생하는 문제입니다.

    릴리스 예정인 11.2 Patch 4에서 해결되었습니다.

    현재까지 릴리스 되어 있는 11.2 버전부터 11.2 Patch 3까지는 동일한 현상이 발생합니다.


    아래 쿼리엣서 /*+ NO_MERGE */ 힌트를 추가하시면 10.2, 11.0 버전과 동일하게 동작합니다.

    하지만 11.2버전에서 개선된 인라인 뷰에 대한 뷰 머징 기능이 동작하지 않아서 권장하지 않습니다.

    현재 발생하는 현상을 해결하는 용도로만 사용해주세요.

     

    SELECT * FROM (SELECT ROWNUM rn, TB.* FROM (SELECT /*+ NO_MERGE */ * FROM... ORDER BY...) TB ) Z WHERE RN BETWEEN 1 AND 10;

     

    근본적인 해결에 대해서는 11.2 Patch 4가 5월 초에는 릴리스될 예정이니 기다려주시면 감사하겠습니다.

     

    ROWNUM으로 순번을 생성하고, 인라인 뷰로 묶어서 BETWEEN... AND...로 페이징 처리를 하는 것은 Oracle 스타일의 페이징 처리 방법입니다.

    쿼리 변경에 문제가 없으시다면 인라인 뷰를 사용하지 않고, LIMIT으로 페이징 처리를 하는 것을 권장드립니다.

  • ?
    바보똥개 2023.04.14 16:39
    답변 감사합니다. 일단 원인이라도 확인했으니 다행이라 생각이 드네요.
    쿼리는 일단 limit로 바꿔서 처리 가능하니 limit로 변경해 사용하도록 하겠습니다.
    즐거운 주말 보내세요.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 21 admin 2024.04.23 143799
4208 특정 데이터 삭제 여부 및 존재기록 확인문의 2 far 2025.07.14 1685
4207 액티브+트랜잭션 로그를 사용한 복구 방법이 있나요? 1 로키 2025.07.09 1968
4206 function생성 질문 4 wltkd96 2025.07.09 1913
4205 gettransactioninfo 응답 값에 sql_text가 없는 이유 문의드립니다. 1 file ogu 2025.07.09 1879
4204 트리거 조회시 권한 없음 1 큐피 2025.06.26 1904
4203 CUBRID 9.3 & 디비버(DBeaver)에서 테이블 탐색기 없음 관련 문의1 1 빠리 2025.06.26 2460
4202 큐브리드 데이터베이스 디스크 변경 문의사항입니다. 1 난지수 2025.06.25 2078
4201 11.3 서비스 오픈 바인드 변수 처리 시 성능 5 file abc123 2025.06.25 2220
4200 jdbc 연동 오류 문의 2 cuji 2025.06.25 2272
4199 11.3 version tranlist 에서 tran time 이 계속 증가하는 원인 파악 하는 방법 문의 1 abc123 2025.06.24 2125
4198 cubrid 11.4 이후 버전에서 시스템 카탈로그 뷰 조회시 반드시 소문자를 사용 해야 하는데 정책이 변경 된 것인가요? 1 두목원슝 2025.06.13 2538
4197 윈도우를 재 설치 하면서 cubrid를 재 사용 하려고 합니다. mango 2025.06.11 2489
4196 CM 에서 DB 로그인 시 Request is rejected due to invalid token. Please reconnect 에러 발생 1 정원 2025.06.05 2727
4195 cubrid shutdown 현상 1 hyoseon-_- 2025.05.28 2597
4194 테이블 생성시 TIMESTAMP 타입의 컬럼이 생성되지 않습니다 4 file 윤덕현 2025.05.27 2586
4193 숫자형 데이터를 지정된 패턴 형식으로 표시 방법 문의 2 종이 2025.05.22 2361
4192 cubrid cci 함수 실행시 SIGPIPE 오류 가을이아빠 2025.05.22 2290
4191 프로시저 작성시 로그 관련 문의 3 바보똥개 2025.05.22 2196
4190 DB 이중화 설정 1 file 유비 2025.05.21 2441
4189 Rocky 8.10 으로 전환 관련 문의 1 루비 2025.05.07 2636
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 213 Next
/ 213

Contact Cubrid

영업문의 070-4077-2112 / 기술문의 070-4077-2148 / 대표전화 070-4077-2110 / Email. contact_at_cubrid.com
Contact Sales