Background Image

FORUM

조회 수 18158 추천 수 0 댓글 1
?

단축키

Prev이전 문서

Next다음 문서

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

아래와 같이 임시 테이블을 생성했습니다.
CREATE TABLE TBL_TEMP
(
    FLD_STRING NCHAR(10)
)
필드는 유니코드를 저장하기 위해 NCHAR 타입으로 생성했습니다.

그리고 아래와 같이 임의의 문자열 10글자를 인서트했습니다.
INSERT INTO TBL_TEMP VALUES(N'abcdefghij');

그리고 C#에서 SELECT 테스트를 하기 위해 코드상에서 "SELECT * FROM TBL_TEMP"로 쿼리했습니다.

이렇게 빌드하면 문자열은 5글자 즉, 'abcde'까지만 반환합니다. 즉, 생성한 필드길이의 절반길이만 반환합니다.
필드 길이를 달리해도 마찬가지구요.

그래서 필드의 데이터 타입을 CHAR로 변경해봤습니다.
그러니 비로소 제대로 반환되네요.

C#이 기본적으로 유니코드이므로 NCHAR 타입으로 생성한건데,
MSSQL에서는 NCHAR형으로 테스트해서 정상작동을 확인했었는데,
큐브리드는 유니코드 문자열도 CHAR형으로 생성해야 하나요? 그럼 NCHAR형의 용도는...

C# 코드를 올려봅니다.

OleDbConnection oledbcon = new OleDbConnection("Provider=CUBRID OLE DB Provider;Location=systronics.iptime.org;Data Source=SysEye;User ID=dba;Cache Authentication=False;Encrypt Password=False;Mask Password=False;Persist Encrypted=False;Persist Security Info=False;Port=33000;Fetch Size=100");

oledbcon.Open();

OleDbCommand command = new OleDbCommand("select * from tbl_temp", oledbcon);
command.CommandType = CommandType.Text;

OleDbDataReader or = command.ExecuteReader();

while (or.Read())
{
    string date = or.GetString(or.GetOrdinal("fld_string"));
}

or.Close();
oledbcon.Close();

  • ?
    남재우 2009.12.21 20:55
    CUBRID 는 현재 언어코드셋을 지원하지 않습니다. 따라서 유니코드를 사용한다고 해서 다른 타입을 쓰실 필요없이, char 나 varchar 를 적절히 쓰시면 됩니다.
    주의하실 점은 substr 이나 length 는 전부 byte 단위로 처리하고 있으므로 이점 유의하셔야 합니다.
    아울러 유니코드 사용시 like 검색을 위하여 cubrid.conf 에 아래 내용을 추가하셔야 합니다.
    single_byte_compare=yes

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 new admin 2024.04.23 19
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4452
1011 백업시 lgar 파일이 지워지지 않는 문제 6 동현 2011.06.11 20360
1010 ResulstSet이 닫혔는데... 닫히는 이유가 먼가요? 3 안지민 2011.06.10 15607
1009 ODBC, OLEDB 접속후, ADO 프로그래밍을 했을 때.. 1 lkim 2011.06.09 13577
1008 cubird-php 연동이 안됩니다. (php-4.4.9) 1 sihal7 2011.06.09 13732
1007 큐브리드 64비트 에서 32비트로 DB이전이 안됩니다. 도와주세요!~ 2 린설 2011.06.07 13098
1006 php - cubird 연결 부분 오류 문제 다시 문의 드립니다. 5 file 김우람 2011.06.04 14334
1005 Cubrid 2008 R2.2 버전 한글 깨짐 관련 문의 1 ezzone 2011.06.04 18468
1004 "DBMS, 0, Unknown DBMS error" 요건 무슨 애러인가요?;; 2 eitetu 2011.06.02 14296
1003 Java procedure 등록 이후 실행 시 NullpointException 발생 1 머루탱 2011.06.02 15164
1002 This object is in a zombie state 인 경우 1 유겸아빠 2011.06.01 12070
1001 트랜잭션의 상세정보를 확인할수 있는 방법이 있나요? 1 김현성 2011.06.01 10562
1000 데이터베이스 클래스수와 성능과의 관계에 대한 질문 1 김현성 2011.06.01 9765
999 TIMESTAMP 형 data를 insert 하는 sql문이 궁금합니다. 1 yongsu9 2011.05.28 34977
998 복제 지연 로그의 최대 라인수 지정 디폴트값?? 2 닉넴 2011.05.27 10322
997 복제 DB가 생성이 되질 않습니다... 긴급!! 2 닉넴 2011.05.27 10662
996 트랙잭션이 시스템에 의해 중단됩니다. 1 김현성 2011.05.26 11019
995 HA 문의 드립니다. 5 뽀로꾸 2011.05.26 20226
994 테스트 한 결과 때문에 질문글 올립니다... 2 secret 반짝이 2011.05.24 17
993 안녕하세요~ insert시 자동 증가값을 알고 싶어서 이렇게 글을 올립니다. 2 yongsu9 2011.05.21 13972
992 어떻게 해야하는건가요? 2 SoMa 2011.05.21 8233
Board Pagination Prev 1 ... 145 146 147 148 149 150 151 152 153 154 ... 200 Next
/ 200

Contact Cubrid

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