Background Image

FORUM

2009.12.23 02:13

BLOB 데이터 select 질문

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

단축키

Prev이전 문서

Next다음 문서

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

아래의 테이블의 데이터를 select 하고자 합니다.
create table tbl_test
(
    fld_sn integer primary key,
    fld_data bit varying(2048)     // 최대 256바이트 저장
)

c++과 연동하여 위 테이블에서 데이터를 select 하기 위해 아래와 같이 소스를 작성했습니다.
MS_SQL과 연동했을 때 사용했던 소스입니다.
궁금한건 화살표로 표시된 부분에서 BLOB 데이터를 획득하려 하는데 문자열로 반환해버리더군요.
MS-SQL에서는 vBlob.vt 값이 VT_ARRAY | VT_UI1으로 리턴되는데, 큐브리드는 VT_BSTR로 반환하네요.
데이터를 핸들링하는 부분을 다른 방법을 써야 할까요?

거듭되는 질문폭탄 죄송합니다ㅜㅜ 초짜인지라...

void BLOBSelect_SQLServer(_ConnectionPtr pConnection) throw(...)
{
 _CommandPtr command = NULL;
 _RecordsetPtr pRecordset = NULL;

 TESTHR(command.CreateInstance(__uuidof(Command)));

 command->ActiveConnection = pConnection;
 command->CommandText = _bstr_t("select * from tbl_test");
 command->CommandType = adCmdText;

 pRecordset = command->Execute(NULL, NULL, adCmdText);

 while(!(pRecordset->adoEOF))
 {
  int sn =  pRecordset->Fields->Item["FLD_SN"]->Value;
  _variant_t vBlob = pRecordset->Fields->Item["FLD_DATA"]->Value;  // <---- 이곳이 MS-SQL과 차이가 나는 부분입니다.

  BYTE* pData;
  BYTE data[256] = {0,};

  if(vBlob.vt == (VT_ARRAY | VT_UI1))
  {
   SafeArrayAccessData(vBlob.parray, (void**)&pData);
   bloblength = vBlob.parray->rgsabound[0].cElements;

   memcpy(data, pData, bloblength);
   SafeArrayUnaccessData(vBlob.parray);
  }

  pRecordset->MoveNext();
 }

 if(pRecordset)
  pRecordset->Close();
}

  • ?
    시난 2009.12.25 02:13
    현재 해당 부분에 대해 개선 예정입니다.
    추후 릴리즈에 포함될 때 연락드리도록 하겠습니다.

List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 115
157 CMT 관련 문의 드립니다. 2 secret 스마트 2010.12.29 8
156 CM 건의 드립니다.... 1 유니콘 2010.12.04 7619
155 CM Manager, Query Broswer SQL result 개행 문제 3 소라게 2013.05.25 8976
154 CLOB타입컬럼이 있는 테이블에 레코드 입력 시 오류가 납니다. 1 secret 사이어스 2015.12.08 14
153 CLOB 포함 테이블 내보내기/가져오기 좀 도와주세요 ㅠㅠㅠ 1 유릉 2014.11.10 10182
152 CLOB 파일 주소 오류 4 file khs 2017.07.22 329
151 CLOB 타입의 데이터 형 반환 1 secret 박성규 2011.01.20 17
150 CLOB 타입 NOT NULL 허용이 안되는지요? 1 최범규 2017.03.31 9490
149 CLOB 데이터 타입 질문 1 하늘같은바다 2013.01.15 7141
148 CLOB 내보내기 질문입니다ㅠ..ㅠ 2 유릉 2014.11.07 8683
147 CLASS 삭제문의 1 키싱유 2014.01.17 9342
146 CCI_PCONNECT 사용 여부에 따라 브로커가 죽거나 행 상태에 빠질 수도 있습니까? 1 섭개발자 2012.11.10 6592
145 CCI 프로그램을 하려면 어떻게 해야하나요? 2 나동호 2009.03.22 10663
144 CCI 프로그램 예제나 자료 나와 있는데 없나요?? 2 나동호 2009.03.24 10663
143 CCI 예제 프로그램이 실행이 안되요;; 5 file 나동호 2009.03.21 14972
142 CCI 라이브러리 배포에 관해서 2 뀨브리드 2015.05.28 4115
141 CCI API로 구현시 DB를 원격에서 접속할 때 발생하는 문제 2 nimbus89 2012.09.01 5971
140 CCI API로 DB Insert 구현 시 JDBC 구현에 비해 속도가 떨어지는 문제 2 nimbus89 2012.08.17 7926
139 CCI API가 Thread Safe 한가요? 3 nimbus89 2012.09.04 7254
138 CCI API 에서 LNK 2019문제가 계속 발생합니다 1 poipoi 2014.05.22 10554
Board Pagination Prev 1 ... 146 147 148 149 150 151 152 153 154 155 ... 158 Next
/ 158

Contact Cubrid

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