Background Image

FORUM

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

단축키

Prev이전 문서

Next다음 문서

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

* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
OS
리눅스64비트
CUBRID Ver.
10.1.7669
CUBRID TOOL Ver.
10.0.01
응용 환경(API)
java, 전자정부프레임워크

* CUBRID 응용 오류, SQL 오류 또는 SQL 튜닝 관련된 문의는 반드시 다음의 내용을 추가해 주세요. 비밀글이나 비밀 댓글도 가능합니다.
* 저희가 상황을 이해하고, 재현이 가능해야 알 수 있는 문제들이 많습니다. 가능한 정보/정황들을 부탁합니다.
에러 내용 및 재현 방법 재현 가능한 Source와 SQL
관련 테이블(인덱스, 키정보 포함) 정보 CUBRID 홈 디렉토리 아래 log 디렉토리 압축


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


다름이 아니라 오라클에서 사용하던 쿼리 변환 중에 


오류는 안나는데 질의 결과가 다르게 나와서 문의드립니다.


간략화해서 쿼리를 쓰자면



SELECT 

          PK_CD,

          PK_NM,

          KEY_CD

FROM

          AAA

LEFT OUTER JOIN 

(

        SELECT

ID,

                *

        FROM

                CCC

) AS BBB

LEFT OUTER JOIN DDD

 ON DDD.KEY_CD = CASE WHEN BBB.KEY_CD IS NOT NULL

                           THEN BBB.KEY_CD

                           ELSE AAA.KEY_CD

                           END

..... 생략 



구조는 대략 이런 식이고


AAA라는 테이블에 LEFT OUTER JOIN으로 

서브쿼리 형식으로 테이블을 만들어 이름을 BBB로 지정하고

거기에 또 LEFT OUTER JOIN 으로 DDD라는 테이블을 조인시키는데


DDD테이블 JOIN 시킬 때 BBB 테이블의 KEY_CD 라는 컬럼이 NULL이 아니면

해당 컬럼을 이용해서 JOIN하고 

NULL이면 AAA 테이블의 컬럼을 이용해서 JOIN 하려고 하는데요


오라클에서는 질의 수행에 이상없으나 

큐브리드 매니저로 쿼리를 수행하면 일단 오류발생은 안합니다.


다만 질의 조건은 BBB 테이블 질의 결과가 0행이면 IS NOT NULL 조건에는 해당되지 않으니

ELSE 구문을 타서 DDD.KEY_CD = AAA.KEY_CD 조건이 걸리도록 되어 있는 쿼리인데

지금 문제가 AAA.KEY_CD 컬럼 값이 NULL인 경우에는

질의 결과가 LEFT OUTER JOIN인데도 불구하고 AAA.KEY_CD 가 NULL인 ROW는 결과에서 제외되서 나옵니다.


진하게 표시된 부분이 최종적으로


ON DDD.KEY_CD (널 아님) = AAA.KEY_CD (NULL인 경우도 있고 아닌 경우도 있음)

이런 형태가 되는데요 처음 셀렉트 자체를 AAA에서 했으니 LEFT OUTER JOIN이 쿼리 결과 카운트에는 영향을 주면 안되는데

위와 같은 문제가 발생해서 문의드립니다.


CASE WHEN BBB.KEY_CD IS NOT NULL 이 부분을 1=2 이런 식으로 바꾸면 ROW 카운트 이상 없이 나오는거 보면

BBB.KEY_CD IS NOT NULL 이 부분을 만나면서 문제가 있어서 결과에 영향을 주는 것 같은데 원인을 모르겠네요..



  • ?
    권호일 2018.04.27 16:40
    아래와 같이 변경해서 해 보시기 바랍니다.

    LEFT OUTER JOIN DDD
    ON ( BBB.KEY_CD IS NOT NULL AND DDD.KEY_CD = BBB.KEY_CD )
    AND ( BBB.KEY_CD IS NULL AND DDD.KEY_CD = AAA.KEY_CD )
  • ?
    잉여개발자 2018.05.15 15:03
    이대로 하니 row에는 영향이 안가는데 join한 DDD 정보들이 다 NULL로 나오네요 ㅠ

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 55
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4461
3715 큐브리드에서 오프소스 Talend 사용 가능한 지 문의드립니다. 3 본부장 2021.05.24 185
3714 큐브리드에서 오라클로 연동할 수 있나요? 1 현쥬리 2009.11.02 10198
3713 큐브리드에서 멀티 데이터베이스를 지원하나요? 1 까망군 2009.11.21 9529
3712 큐브리드에서 덤프하는 방법 질문하겠습니다. 1 겸둥이k 2021.08.04 1243
3711 큐브리드에서 ddl 를 뽑아내고 싶습니다. 3 varsql 2020.05.18 796
3710 큐브리드에도 테이블 정보를 담고 있는 DB가 있나요? 2 파란토끼 2013.09.27 9959
3709 큐브리드에 제공하는 파티셔닝 사용후 조회시 문제 5 file 연습용 2021.09.01 169
3708 큐브리드에 있는 sql데이터를 다른사이트에 표출하는방법 3 꼴통개발자 2019.11.05 180
3707 큐브리드에 데이타 타입 지정문제 4 지니보이 2009.12.26 20203
3706 큐브리드에 db link 기능이 있나요? 1 김성일컴퍼니 2013.07.18 10413
3705 큐브리드에 Synonym기능 있나요? 1 김성일컴퍼니 2013.07.18 10890
3704 큐브리드에 PK, FK, INDEX 이름명 변경 신텍스 문의 드립니다. 1 덴드로비움 2017.08.30 1068
3703 큐브리드앱스팩 설치문의 1 오케이디바이스 2009.11.26 9069
3702 큐브리드설치에러;; 1 가루구 2009.02.14 12593
3701 큐브리드설정 문의 5 초보 2010.04.13 10026
3700 큐브리드상에서 한글을 깨지지 않고 자르는 방법이 있을까요? 1 file 안지민 2012.03.13 9326
3699 큐브리드메니저 브로커 접속 에러 - 353 1 leemited 2020.06.24 172
3698 큐브리드매니져로 테이블에 MULTISET 추가시 1 하나엘 2009.12.02 10126
3697 큐브리드매니저의 아이콘 개선 요청 3 file 고영진 2009.09.24 11361
3696 큐브리드매니저에서서버접속시연결오류가납니다 2 secret 훈이아빠 2016.12.01 15
Board Pagination Prev 1 ... 10 11 12 13 14 15 16 17 18 19 ... 200 Next
/ 200

Contact Cubrid

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