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. windows 환경에서 압축파일로 CUBRID 설치시 환경변수 쉽게 설정하기

    Date2015.07.02 Category운영관리 By김승훈 Views6995
    Read More
  2. CUBRID dummy data생성-간단편

    Date2015.07.01 Category질의작성 By주현 Views7858
    Read More
  3. CUBRID HA에서 사용하는 포트 확인 방법(1523, 59901)

    Date2015.07.01 Category기타 By주현 Views8164
    Read More
  4. 카디시안(한 Row를 여러 Row) 쿼리문 만들기

    Date2015.06.30 Category질의작성 By엄기호 Views10927
    Read More
  5. 32bit JRE 환경에서 64bit CUBRID Tool 사용

    Date2015.06.30 CategoryCUBRID 매니저 By손승일 Views7190
    Read More
  6. CUBRID Manager 및 엑셀 파일을 이용하여 데이터 입력 시, garbage값이 포함되어 저장되는 경우 해결 방법

    Date2015.06.17 CategoryCUBRID 매니저 By이용미 Views9754
    Read More
  7. SQL튜닝 - 인덱스 활용 사례

    Date2015.06.04 Category질의작성 By권호일 Views12013
    Read More
  8. JAVA SP 사용 시 로그 처리 방법

    Date2015.06.03 Category응용개발 By손승일 Views8574
    Read More
  9. 디비와 테이블 문자셋이 다른 경우 처리 방법

    Date2015.06.03 Category운영관리 By이용미 Views15802
    Read More
  10. A테이블의 다수의 컬럼을 B테이블로 UPDATE 하는 SQL

    Date2015.05.07 Category질의작성 By김승훈 Views7411
    Read More
  11. 전체 레코드 개수 확인하는 SP

    Date2015.05.07 Category응용개발 By김승훈 Views14726
    Read More
  12. MERGE INTO 사용 예제 ( INSERT, UPDATE문을 1개의 쿼리로 실행 )

    Date2015.05.01 Category질의작성 By권호일 Views21252
    Read More
  13. 워크스페이스 사용중입니다. 다른 워크스페이스를 선택하세요. 대응법

    Date2015.04.24 CategoryCUBRID 매니저 By성진 Views10507
    Read More
  14. CUBRID Manager 메모리 설정하기(cubridmanager.ini)

    Date2015.04.24 CategoryCUBRID 매니저 By성진 Views13707
    Read More
  15. CUBRID HA와 Primary key 제약조건

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

    Date2015.02.03 Category운영관리 By정만영 Views11451
    Read More
  17. cubrid manager server 구동 시 no "events" section in configuration 오류 발생

    Date2014.07.03 CategoryCUBRID 매니저 By손승일 Views10262
    Read More
  18. 9.2 버전에서 복제 재구축(ha_make_slavedb.sh) 스크립트를 사용하려면 수정해야 할 부분

    Date2013.10.24 Category운영관리 Bybrightest Views12231
    Read More
  19. CUBRID vs MySQL vs ORACLE SQL 타입별 비교

    Date2013.07.12 Category마이그레이션 By정만영 Views69158
    Read More
  20. 오류데이타검증 - 숫자 이외의 데이타 확인하는 방법

    Date2013.01.17 Category질의작성 By권호일 Views21121
    Read More
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 14 Next
/ 14

Contact Cubrid

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