Background Image

FORUM

2009.12.23 02:13

BLOB 데이터 select 질문

조회 수 12310 추천 수 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 4441
» BLOB 데이터 select 질문 1 hyperhand 2009.12.23 12310
465 Java SP 질문 9 hyperhand 2009.12.23 11178
464 이중 루프문 안에 쿼리문 실행시 바깥루프 안도는 문제 1 지니보이 2009.12.22 15270
463 AUTO_INCREMENT 컬럼 이용시 2 hyperhand 2009.12.22 17648
462 java stored procedure 실행시 에러 4 hyperhand 2009.12.22 23365
461 c#과 cubrid2008 연동후 문자열 select 질문. 1 hyperhand 2009.12.21 18158
460 R1.4->R2.0(64비트)베타 업그레이드 및 마이그레이션후 DB접속불가. 1 xclass 2009.12.21 11763
459 Client만 설시치 oledb provider가 설치되지 않습니다. 1 hyperhand 2009.12.19 13687
458 오라클과의 성능에 대한 비교를 알고 싶습니다. 1 secret 오004 2009.12.16 11
457 오라클과의 호환성과 대용량 검색 속도 1 오004 2009.12.16 26155
456 조인 관련 질문입니다. 3 지니보이 2009.12.16 9856
455 cubrid_prepare()로 데이타 입력시 질문입니다. 1 지니보이 2009.12.16 9824
454 row level lock 이 지원되나요? 5 초보대왕 2009.12.16 13160
453 한글이 깨지네요 2 썬해바라기 2009.12.16 10314
452 restordb를 사용후 다른 문구가... 1 썬해바라기 2009.12.15 9415
451 Unloaddb의 문제점 1 앵벌이 2009.12.14 9690
450 mysql로 마이그레이션하는방법좀.. 1 썬해바라기 2009.12.14 10493
449 큐브리드 6.6에서 큐브리드 2008로 복구하는 방법좀.. 1 썬해바라기 2009.12.14 9506
448 큐브리드 테이블 스페이스 생성 스크립트 정보 확인 방법 3 박훤석 2009.12.12 16709
447 파워빌더 10.5 ODBC 연결 오류 2 카이 2009.12.11 19541
Board Pagination Prev 1 ... 172 173 174 175 176 177 178 179 180 181 ... 200 Next
/ 200

Contact Cubrid

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