Background Image
조회 수 15802 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
CUBRID 9.x 버전에서 DB 생성 시의 문자셋과 테이블 또는 컬럼에서 지정한 문자셋이 다를 때, 데이터 출력시 깨져서 보이는 경우가 있다.

환경] DB COLLATE를 en_US, 문자셋은 iso88591로 생성 및 UTF8 문자셋의 테이블 생성.
$ cubrid createdb tmp en_US
Creating database with 512.0M size using locale en_US. The total amount of disk space needed is 1.5G.

CUBRID 9.2

$ csql -u dba -S tmp

        CUBRID SQL Interpreter


Type `;help' for help messages.

csql> select charset('');

=== <Result of SELECT Command in Line 1> ===

   charset('')        
======================
  'iso88591'          

1 rows selected. (0.011982 sec) Committed.

1 command(s) successfully processed.
csql> create table tmp(col1 int auto_increment, col2 varchar(5) COLLATE utf8_bin) COLLATE utf8_ko_cs;
Execute OK. (0.001303 sec) Committed.

1 command(s) successfully processed.

일반적인 INSERT 문을 사용하여 데이터를 입력하면 데이터가 깨져서 보인다.
예1]
csql> insert into tmp(col2) values('가');
1 row affected. (0.009916 sec) Committed.

1 command(s) successfully processed.
csql> select * from tmp;

=== <Result of SELECT Command in Line 1> ===

         col1  col2                
===================================
            1  'ê°?'             

1 rows selected. (0.019385 sec) Committed.

1 command(s) successfully processed. 


위와 같은 경우에는 데이터 입력 시, 따로 지정된 문자셋이 없어 DB 생성시의 문자셋인 iso8859-1로 데이터가 입력되어 발생한다.

해당 문제는 아래와 같은 2가지 방법으로 UTF8 데이터를 입력할 수 있다.
1. 문자셋 소개자 사용 : INSERT INTO TABLE_NAME(COL2) VALUES(_UTF8'큐브리드');
예2]
csql> insert into tmp(col2) values(_utf8'나');
1 row affected. (0.000220 sec) Committed.

1 command(s) successfully processed.
csql> select * from tmp;

=== <Result of SELECT Command in Line 1> ===

         col1  col2                
===================================
            1  'ê°?'             
            2  '나'               

2 rows selected. (0.011894 sec) Committed.

1 command(s) successfully processed.

 

2. 문자셋을 명시 : SET NAMES UTF8;
                      INSERT INTO TABLE_NAME(COL2) VALUES('큐브리드');
예3]
csql> set names utf8;
Execute OK. (0.000025 sec) Committed.

1 command(s) successfully processed.
csql> insert into tmp(col2) values('다');
1 row affected. (0.000282 sec) Committed.

1 command(s) successfully processed.
csql> select * from tmp;

=== <Result of SELECT Command in Line 1> ===

         col1  col2                
===================================
            1  'ê°?'             
            2  '나'               
            3  '다'               

3 rows selected. (0.011805 sec) Committed.

1 command(s) successfully processed. 


문자셋과 콜레이션은 다음과 같은 우선 순위를 같는다.
1. 문자셋 소개자(또는 문자열의 COLLATE 수정자)
2. SET NAMES문으로 명시한 문자셋과 콜레이션
3. 시스템 문자셋과 콜레이션(DB 생성 시 지정한 로캘에 의한 기본 콜레이션)

예제1에서는 위 우선 순위 중 1, 2번으로 명시된 문자셋이 없었으니 데이터 입력 시 '3번 시스템 문자셋과 콜레이션'을 사용하였기 때문에 이후 결과물 출력 시 데이터가 깨져보이는 현상이 발생했었던 것이다.
예제 2와 예제 3에서는 위 우선 순위에 해당하는 1, 2번이 각각 사용되어 테이블 문자셋과 동일한 문자셋으로 데이터를 입력하였기 때문에 이후 결과물 출력 시 데이터를 정상적으로 확인할 수 있는 것이다.



  1. CUBRID 브로커와 시스템 메모리

    Date2019.03.12 Category운영관리 By정만영 Views2369
    Read More
  2. 윈도우 OS에서 java sp 사용 시 Java VM is not running 해결 방법

    Date2017.09.04 Category운영관리 By정훈 Views2229
    Read More
  3. CUBRID 8.2.2 ~ 8.4.x 버전에서 'ALTER SERIAL ... CACHE <cached_num> / NOCACHE' ERROR 해결 방법

    Date2017.03.08 Category운영관리 By주영진 Views2161
    Read More
  4. 큐브리드 포트 정리

    Date2016.07.05 Category운영관리 By정만영 Views6091
    Read More
  5. 큐브리드 마스터 소켓 디렉토리 변경방법

    Date2016.07.05 Category운영관리 By정만영 Views4218
    Read More
  6. Invalid XASL tree node content 에러

    Date2016.04.26 Category운영관리 By손승일 Views4477
    Read More
  7. 산술 연산 결과를 피젯수 또는 젯수의 자리 수에 맞춰 보자.

    Date2016.03.01 Category운영관리 By성진 Views4816
    Read More
  8. 'Has been interrupted.' CUBRIDException 발생

    Date2016.01.07 Category운영관리 By주현 Views6588
    Read More
  9. CUBRID BACKUP (linux, window)

    Date2015.12.30 Category운영관리 By박동윤 Views6246
    Read More
  10. 브로커와 DB 간 연결 테스트

    Date2015.12.29 Category운영관리 By박동윤 Views4934
    Read More
  11. cubrid plandump ( plan cache정보확인)

    Date2015.12.29 Category운영관리 By주현 Views4300
    Read More
  12. 시스템 부하가 많지 않음에도 불구하고 질의 수행이 느린 경우 THP 기능 설정 확인 및 해제

    Date2015.12.16 Category운영관리 By진우진 Views7526
    Read More
  13. 큐브리드 서비스 재구동 시 cubrid manager server start: fail 오류 해결 방법

    Date2015.12.16 Category운영관리 By진우진 Views7732
    Read More
  14. 브로커 동적 파라미터 변경 방법

    Date2015.08.13 Category운영관리 By정만영 Views7566
    Read More
  15. CUBRID HA 구성 후 구동중인 slave/replica node에서 write 하기

    Date2015.07.15 Category운영관리 By정만영 Views9043
    Read More
  16. windows 환경에서 압축파일로 CUBRID 설치시 환경변수 쉽게 설정하기

    Date2015.07.02 Category운영관리 By김승훈 Views6995
    Read More
  17. 디비와 테이블 문자셋이 다른 경우 처리 방법

    Date2015.06.03 Category운영관리 By이용미 Views15802
    Read More
  18. CUBRID HA와 Primary key 제약조건

    Date2015.04.21 Category운영관리 By정만영 Views11347
    Read More
  19. 테이블 사용량 확인방법

    Date2015.02.03 Category운영관리 By정만영 Views11452
    Read More
  20. 9.2 버전에서 복제 재구축(ha_make_slavedb.sh) 스크립트를 사용하려면 수정해야 할 부분

    Date2013.10.24 Category운영관리 Bybrightest Views12231
    Read More
Board Pagination Prev 1 2 3 4 Next
/ 4

Contact Cubrid

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