Background Image

FORUM

2009.12.23 02:13

BLOB 데이터 select 질문

조회 수 12317 추천 수 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 142
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4481
3865 트리거 생성시 문법 질문 1 초콜릿75 2013.07.03 13431
3864 트리거 삭제 오류 1 file slqk135 2024.01.08 91
3863 트리거 사용시 임시변수 1 지구인다 2018.10.01 253
3862 트리거 등록 후 정보 확인시 오류사항 2 file 종이 2014.08.11 8531
3861 트리거 동작 문의 1 종이 2016.08.12 14126
3860 트리거 inactive 오류 1 단순미학 2010.07.01 8051
3859 트리거 delete on 문법 문의 1 aliveJune 2009.10.05 10742
3858 트리거 delete after시 상관명을 써야합니다. 1 루피 2013.11.07 19636
3857 트리거 ACTIVE/INACTIVE 설정 2 할리 2014.06.18 7842
3856 트랜젝션 처리에 대해 1 kkndo2 2015.04.13 8337
3855 트랜잭션처리 시간지연에 대한 문의입니다. 2 file 히로키 2009.12.03 12338
3854 트랜잭션이(인덱스 1, dba@localhost|20383) 시스템에 의해 취소되었습니다. 1 스마트 2011.01.06 8012
3853 트랜잭션의 상세정보를 확인할수 있는 방법이 있나요? 1 김현성 2011.06.01 10568
3852 트랜잭션과 커밋에 관한 질문 2 유니콘 2011.03.03 10228
3851 트랜잭션 오류 문의 1 oneh 2018.07.18 382
3850 트랜잭션 교착상태 1 초보 2010.04.14 11936
3849 트랜잭션 관련하여 질문드립니다. 6 봉보로봉봉 2017.08.02 415
3848 트랜잭션 관련 추가 문의입니다. 5 메이커스 2009.07.31 9152
3847 트랜잭션 관련 문의입니다. 4 메이커스 2009.07.25 9314
3846 트랜잭션 격리 수준 관련한 에러 메시지 6 file gjgj 2021.07.15 156
Board Pagination Prev 1 ... 3 4 5 6 7 8 9 10 11 12 ... 201 Next
/ 201

Contact Cubrid

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