Background Image
조회 수 15340 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

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

1. 개요

  CUBRIDOracle  NULL, ‘’(empty string)의 차이점을 확인한다.



2. 테스트 시나리오

  1) 샘플 테이블(test_table)에 char(10), varchar(10)을 생성

  2) 샘플 데이타 테스트, null, ''(empty string)을 입력

  3) select 실행 및 결과 비교



3. 세부 시나리오
1) test_table 생성 ( CUBRID, Oracle 동일 )


 create table test_table ( id varchar(100), col1 char(10), col2 VARCHAR(10) );     



2) 샘플 데이터 입력 ( CUBRID, Oracle 동일 )


insert into  test_table values  ('value', 'cubrid', 'cubrid') ;

insert into  test_table values  ('null', NULL, NULL ) ;

insert into  test_table values  ('empty string', '', '' ) ;



3) select 쿼리 실행 및 비교 ( CUBRID, Oracle 동일 )
- select 쿼리


select id, col1, length(col1) col1_length, nvl(col1, 'null') col1_null_check,

col2, length(col2) col2_length, nvl(col1, 'null') col2_null_check

from       test_table ; 






- CUBRID 실행결과

NO

id

col1

col1_length

col1_null_check

col2

col2_length

col2_null_check

1

Value

cubrid

10

cubrid

cubrid

6

cubrid

2

Null

(NULL)

(NULL)

null

(NULL)

(NULL)

null

3

Empty string

 

10

 

 

0

 

- Oracle 실행결과

NO

id

Col1

Col1_length

Col1_null_check

Col2

Col2_length

Col2_null_check

1

Value

cubrid

10

cubrid

cubrid

6

cubrid

2

Null

(NULL)

(NULL)

null

(NULL)

(NULL)

null

3

Empty string

(NULL)

(NULL)

null

(NULL)

(NULL)

null





3. 테스트 결론

NULL 값과 문자값은 CUBRID, Oracle 모두 동일하게 처리한다.

위 테스트 결과와 같이 id값이 ‘Value’, ‘Null’인 SQL 실행 결과는 동일하다

CUBRID Oracle 모두 char 컬럼 타입과 varchar 컬럼에 데이터를 입력하고 조회 한 결과는 동일 함.  

Char 타입에서 남은 공간은 space(공백)로 채우는 것도 동일

CUBRID Oracle 모두 char 컬럼 타입과 varchar 타입에 Null을 입력하면 동일하게 Null로 처리

 

틀리게 처리하는 내용은 Empty string(‘’)이다.

CUBRID empty string을 ‘’로 처리 함.   Oracle에서는 Empty string(‘’)을 Null로 처리 한다.  

CUBRID에서는 ‘’ char 타입에 입력하면남은 공간을 공백으로 처리하고

Oracle은 ‘’ 값을 입력하면 null로 처리함으로 공백으로 처리하지 않는다.  

Length 함수를 사용하여 길이를 확인 해 보면 

CUBRID에서는 char 컬럼타입은 컬럼 길이만큼 space(공백)으로 체워짐으로 컬럼길이 10이 보여지고

varchar에는 0으로 보여진다.  

그에 반해서 Oracle은 null로 입력 됨으로 length를 체크해도 char, varchar 타입 모두 null로 보여진다.





4. DB 전환 시 유의 사항

위 결과와 같이 컬럼의 값이 NULL 또는 값이 있는 컬럼은 CUBRID와 Oracle이 모두 동일하게 처리함으로 이슈는 없다.


기존 Oracle에서 NULL과 Empty string을 각각 의미 있는 값으로 사용하고 있다면

설계가 잘 못된 것이므로 Empty string을 의미 있는 값으로 처리 될 수 있도록 코드설계를 다시 하는 것이 가장 바람직하다.


그러지 못할 경우에는 아래의 내용을 참고하기 바라며

아래의 해결 방법으로 처리 할 경우에는인덱스를 활용하지 못하여 성능에 큰 영향을 끼칠 수도 있다.


Empty String 데이터 처리의 동일한 결과를 위해서는 입력/수정 처리 또는 조회 처리에서 변경이 필요하다.


Oracle과 동일한 처리를 위해서는

1입력 처리 시에 Empty string Null로 입력되도록 처리

    예시) decode 함수 이용(입력값이 ‘’이면 NULL로 처리)  :  decode(입력값,  ‘’, NULL, 입력값 )

2조회 처리 시에 NULL값 조회(is null, is not null)가 아닌 Empty string값으로 조회처리 되도록 수정

    예시) OR조건으로 NULL과 ‘’값을 함께 조회 : 조회컬럼 is null  OR  조회컬럼 = ‘’ 






  • ?
    엄기호 2016.03.19 00:21

    오라클은 Empty string값 과 NULL값을 동일시 한다.

    - 컬럼의 타입이 date Type이면서 SQL문에 DECODE함수를 사용할 경우

     

    1) 오라클 SQL문

         DECODE( create_dt, '', '', create_dt)

    2) 큐브리드 SQL문(컬럼에 들어 있는 Empty값을 NULL로 작업을 해 놓고 SQL문 변경)

     2.1) CASE WHEN문 사용

            CASE WHEN create_dt IS NULL THEN NULL

                          ELSE create_dt

              END

     2.2) DECODE문 사용

            DECODE(create_dt, NULL,NULL, create_dt)


List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
59 운영관리 CUBRID HA 구성 후 구동중인 slave/replica node에서 write 하기 정만영 2015.07.15 9032
58 질의작성 전체 테이블 UPDATE시 SELECT, UPDATE를 통한 INDEX SCAN방식으로 테이블 X_LOCK을 방지하자! file 이경오 2015.08.13 13770
57 운영관리 브로커 동적 파라미터 변경 방법 정만영 2015.08.13 7555
56 응용개발 WHERE 조건에서 다중 컬럼 IN절 처리 최적화 방법 (cubrid + ibatis) 1 이상신 2015.08.21 55063
55 질의작성 테이블 용량 산정 쿼리 성진 2015.12.08 7371
54 질의작성 오라클의 DBMS_RANDOM.STRING() 함수를 CUBRID 식으로 구현하는 방법 이경오 2015.12.08 7959
53 응용개발 maven에서 CUBRID JDBC Driver 추가하기 file 김승훈 2015.12.09 8902
52 운영관리 큐브리드 서비스 재구동 시 cubrid manager server start: fail 오류 해결 방법 진우진 2015.12.16 7691
51 운영관리 시스템 부하가 많지 않음에도 불구하고 질의 수행이 느린 경우 THP 기능 설정 확인 및 해제 진우진 2015.12.16 7507
50 질의작성 일정 범위 임의의 정수 생성 방법(random 함수 응용) 손승일 2015.12.22 6454
49 CUBRID 매니저 테이블 명세서 한 시트로 합치기 file 성진 2015.12.24 16475
48 마이그레이션 CM(CUBRID Manager)을 이용하여 행정표준코드시스템의 기관코드 가져오기 file 권호일 2015.12.28 6325
» 마이그레이션 CUBRID와 Oracle의 NULL과 '' (empty string)의 처리 차이점 1 권호일 2015.12.29 15340
46 운영관리 cubrid plandump ( plan cache정보확인) file 주현 2015.12.29 4292
45 응용개발 CUBRID HA 제약 사항 및 확인 방법 손승일 2015.12.29 5293
44 운영관리 브로커와 DB 간 연결 테스트 박동윤 2015.12.29 4924
43 질의작성 Cubrid는 어떤 쿼리를 동일한 쿼리로 판단할까? 이상신 2015.12.30 4006
42 운영관리 CUBRID BACKUP (linux, window) file 박동윤 2015.12.30 6218
41 마이그레이션 MySQL 테이블 크기 조사하기-공유 주현 2015.12.31 6197
40 응용개발 CUBRID DB에서 critical section 정보 출력하기 file 주현 2015.12.31 4552
Board Pagination Prev 1 ... 5 6 7 8 9 10 11 12 13 14 Next
/ 14

Contact Cubrid

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