Background Image

FORUM

2009.12.23 02:13

BLOB 데이터 select 질문

조회 수 12311 추천 수 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
번호 제목 글쓴이 날짜 조회 수
공지 CUBRID 사용자를 위한 DBeaver 도구 출시 안내 admin 2024.04.23 116
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4474
1020 큐브리드 2.2로 업그레이드시 single_byte_compare문제 18 지니보이 2010.06.10 10592
1019 XE 이전에 관해... 15 sugarkane 2010.11.24 10616
1018 테이블 구성 방안 문의 2 종이 2012.05.01 10621
1017 MyBatis에서 익명 블럭(Anonymous Block) 사용시 1 손진한 2017.04.03 10621
1016 테이블 삭제시 오류에 대하여... 2 메이커스 2009.08.01 10623
1015 테이블 파티션 -> 일반 테이블 변경 문의 4 초보 2010.04.09 10623
1014 JEUS 사용시 큐브리드 Charset 설정 문의 1 식이77 2014.10.14 10624
1013 테이블 스크립트 얻는 방법이 필요합니다 1 ㅇㅇ 2013.06.25 10625
1012 CCI API 에서 #pragma pack(push,1) 오류 2 David Kang 2009.08.25 10628
1011 loaddb 에러 발생. 2 스팅거 2009.10.09 10629
1010 큐브리드 쿼리 문법 1 신데렐라 2013.04.18 10632
1009 HA 구성오류 답변 부탁드립니다. 7 영길 2013.10.23 10657
1008 디비데이터 조회시 한글이 물음표로 나옵니다. 3 하아품 2016.06.13 10660
1007 복제 DB가 생성이 되질 않습니다... 긴급!! 2 닉넴 2011.05.27 10662
1006 PDO가 지원되고 있는 건가요? 1 kkh 2011.07.09 10663
1005 쿼리 브라우저에서 유저별 현재 사용 data 용량확인 하는 방법 좀 알려주세요 1 황선욱 2014.09.05 10666
1004 bit형 데이터타입 관련 2 소라게 2012.01.27 10671
1003 cubrid 이중화 문의좀드립니다 3 곰팅팅이 2016.03.25 10679
1002 데이타베이스로그인시 lgat화일을 찾으면서 로그인이 안되요.. 2 본좌대바리 2012.02.07 10682
1001 CM서버의 비밀번호를 분실시 cm.pass 초기화 및 connect timed out 관련 문의드립니다. 1 dashbell 2014.07.24 10682
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