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 49
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
754 PDO 지원이 가능한가요? 1 ihwan 2009.05.20 12045
753 cm_admin 으로 사용자를 추가해도 쿼리 브라우저에서 접속 불가합니다..도와주세요 1 asuraiv 2013.12.10 12047
752 window2000에서 사용하게 해주세요. 2 나상숙 2009.04.07 12051
751 데이타베이스 복구에 관한 질문. 1 김우람 2009.03.18 12051
750 modify 질문드립니다. 1 rikal 2016.08.03 12054
749 [긴급] 삭제되지 않는 테이블은 어떻게 처리해야하나요.. 4 스마트 2010.09.25 12056
748 This object is in a zombie state 인 경우 1 유겸아빠 2011.06.01 12070
747 server start시 error 발생 관련 3 flypig 2012.02.24 12075
746 왜 컬럼이름이 안붙나요...... 1 file 안지민 2009.03.06 12075
745 TIME 포맷 관련 질문 입니다. 1 이승훈 2009.03.19 12107
744 데이터베이스 하드차지하는 용량이 계속 늘어요 2 하나엘 2009.11.17 12108
743 큐브리드 재시작 후 처음 조회시 조회가 오래걸립니다. 4 종이 2010.04.24 12108
742 csql 로 demodb 접속 시 오류 입니다~! 1 하하보이 2011.06.29 12110
741 is null 조건 쿼리가 더 오래 걸리는 이유가 무엇인가요? 1 초보 2010.04.06 12118
740 큐브리드 매니저 Xe설치후 게시판관리하려면 1 Kai 2014.01.09 12124
739 오류코드 출력문의 3 뚜벅초 2016.06.17 12130
738 큐브리드와 powerDNS 연동 1 aliveJune 2009.09.04 12139
737 윈도우 -> 리눅스 큐브리드 원격접속 문제 1 박대서 2013.04.21 12157
736 Cubrid FUNCTION 한글 깨짐 문제 1 록밥 2017.02.24 12161
735 디비생성에러 5 file giyoung.kim 2011.10.12 12163
Board Pagination Prev 1 ... 158 159 160 161 162 163 164 165 166 167 ... 200 Next
/ 200

Contact Cubrid

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