Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
서브쿼리에 정렬된 값의 순서에 맞춰 필터링된 결과를 바탕으로 전체 쿼리 결과를 생성하고자 할 경우, 의도하지 않은 방향으로 쿼리 최적화가 이루어지는 것 같습니다. 즉 다음과 같은 쿼리가 있을 때,

select x.* from (
    select t.* from
    (
        select 1 v, 1 c from db_root
        union all select 2, 1 from db_root
        union all select 3, 0 from db_root
        union all select 4, 1 from db_root
        union all select 5, 1 from db_root
    ) t
    order by t.v for orderby_num() between 2 and 4
) x
where x.c = 1

이 쿼리에서 의도한 결과는 다음과 같습니다.
v c
2 1
4 1
그러나 의도와는 다르게 다음의 결과가 도출됩니다.
v c
2 1
4 1
5 1

즉, 서브쿼리의 ORDER BY 구문이 최적화를 거치면서 서브쿼리에 귀속하지않고 최종 결과에 대한 정렬 동작으로 잘못 처리되는 것 같습니다.

이 문제를 해결하기 위한 한가지 우회방법으로 서브쿼리에 불필요한 컬럼 정의를 넣는 방법인데요, 다음처럼 쿼리를 변경하는 것 입니다.

select x.* from (
    select t.*, orderby_num() from
    (
        select 1 v, 1 c from db_root
        union all select 2, 1 from db_root
        union all select 3, 0 from db_root
        union all select 4, 1 from db_root
        union all select 5, 1 from db_root
    ) t
    order by t.v for orderby_num() between 2 and 4
) x
where x.c = 1


그리고 일부 DBMS의 경우 서브쿼리에 ORDER BY 구문을 사용하는데 있어 제약이 있는 경우가 있어서 해당 내용에 대해 온라인 도큐먼트를 참고하려 했는데요, SELECT 구문의 서브쿼리 정의에는 <query statement>라는 모호한 내용만 있습니다. 도큐먼트 어디에도 <query statement>에 대한 정의가 없는데요, 제 생각에는 <query state>로 변경하는 것이 정황상 맞는 것 같습니다.

고쳐주세요!

  • ?
    cubebridge 2010.01.29 21:23
    지금 테스트 해보았습니다.
    사용하신 제품의 정확한 버전(cubrid_rel명령어로 확인이 가능합니다.)을 알려 주시기 부탁드립니다.
    현재 위의 쿼리 대로 R2.1버전에서 확인한 결과 기대하신 값과 동일한 값을 얻었습니다.
    확인 부탁드립니다.
  • ?
    asteroid 2010.01.30 00:10
    R2.0 입니다. R2.1의 릴리스노트를 보니 해결된 문제에 해당 내용이 있네요. 빠른 답변 감사드립니다!

  1. No Image notice by admin 2024/04/23 by admin
    Views 48 

    CUBRID 사용자를 위한 DBeaver 도구 출시 안내

  2. SQLGate for CUBRID 영구 무료 라이선스 제공

  3. Like 문이 의도하지 않은 결과값을 반환합니다.

  4. 한글메세지 출력 방법에 대해서..

  5. 555번 한글테이블 글 올린 사람입니다 (화면캡쳐함)

  6. 저장프로시저 함수-loadjava

  7. group by 오류

  8. 테이블명을 한글로 할 수는 없나요?

  9. timestamp 필드 데이터를 다시 timestamp로 변환하기

  10. 리눅스상에서 백업파일의 Backup Time을 알수있는 방법이 있나요?

  11. restoredb 이용한 복구가 제대로 되지 않아요.

  12. 설치 완료후 phpcubAdmin 에서 페이지 열기가 안됩니다.

  13. 컴포지션 관련해서 문의 드립니다.

  14. 리눅스 설치 확인 부탁 드립니다.

  15. // 를 사용하고 싶습니다.

  16. 큐브리드 매니저에서 오류

  17. 내부 아이피 연결시 접속이 안되는 현상

  18. Spatial Extensions 지원하나요?

  19. 542번글 재질의

  20. MS-SQL 데이타타입/함수비교

  21. 큐브리드 매니저에 데이타베이스 복구가 비활성화 되어있습니다

  22. 데이터베이스 검사시에 에러

Board Pagination Prev 1 ... 168 169 170 171 172 173 174 175 176 177 ... 200 Next
/ 200

Contact Cubrid

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