Background Image

FORUM

2009.12.23 02:13

BLOB 데이터 select 질문

조회 수 12118 추천 수 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 143
228 CUBRID Migration Toolkit 사용시 에러 관련사항입니다. 3 file 그가가가 2012.01.03 18890
227 CUBRID Master start failed 에러... 1 노스 2011.01.29 12969
226 CUBRID Manager에서 접속이 안됩니다. 2 hunter 2014.05.09 6299
225 CUBRID Manager 한글깨짐 3 아하하하하 2015.08.11 9507
224 CUBRID Manager 접속 오류 문의 4 file 미누사랑 2014.05.08 10384
223 CUBRID Manager 오류메시지 문의드립니다. 1 file Ele 2010.06.12 11802
222 CUBRID Manager 영문버전 제공여부 2 bikehee 2017.11.14 131
221 CUBRID Manager 연결 오류 1 sinorix 2013.03.19 9737
220 CUBRID Manager 에서 기본설정 -> 질의 편집기 옵션 -> UTF8로 변경방법 알려주세요! 3 혀니짱 2011.03.24 9985
219 CUBRID Manager 없이 View 소스를 조회 1 file 박승환 2017.09.07 285
218 CUBRID Manager 삭제에 대한 질의입니다. 2 씨유소박 2013.10.29 8090
217 CUBRID Manager R2.0에서 R1.4 서버 연결 1 r77017 2009.11.02 9274
216 CUBRID Manager 9.3.6.007 (64bit) 문제가 있는거 아닌가요? 1 file 라면 2017.03.31 9150
215 CUBRID Manager 9.3.6.007 (64bit) 문제 추가 문의 1 라면 2017.04.07 8102
214 CUBRID Manager 9.3.6.007 (64bit) 에서 엑셀다운로드 안됨 1 자유시간 2017.03.28 7825
213 CUBRID MANAGER가 무반응이에요 1 릴리 2016.12.31 15128
212 CUBRID MANAGER 한글이 깨져서 나오고 입력할 때도 한글이 깨집니다. 4 qswaert 2018.04.12 218
211 CUBRID MANAGER 로그인 실패 5 red03410 2014.06.19 8336
210 CUBRID IP차단기능 관련 질문드립니다. 2 sspark 2018.01.09 235
209 CUBRID HA 제약사항 문의드립니다. 1 뒷태지존 2013.06.19 8821
Board Pagination Prev 1 ... 143 144 145 146 147 148 149 150 151 152 ... 159 Next
/ 159

Contact Cubrid

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