* 질문 등록 시 다음의 내용을 꼭 기입하여 주세요.
리눅스64비트 | |
10.1.7669 | |
10.0.01 | |
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 이 부분을 만나면서 문제가 있어서 결과에 영향을 주는 것 같은데 원인을 모르겠네요..