Background Image

FORUM

2009.12.23 02:13

BLOB 데이터 select 질문

조회 수 12307 추천 수 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 4278
1036 큐브리드 select 성능 관련 문의 1 turbo_jdh 2019.02.19 798
1035 보호된 메모리를 읽거나 쓰려고 했습니다.. 오류가 재발합니다 2 모비23 2019.02.19 8980
1034 jeus 연동 한글등록 문제(깨짐) 4 뺀돌스 2019.02.21 2375
1033 Conversion error in timestamp format 4 세오7 2019.02.22 1010
1032 oracle과 연결해서 조회할 수 있는 방법이 있나요? 7 CuBrId 2019.02.22 733
1031 큐브리드 질문이 있습니다. 2 bjosbkjx 2019.02.25 182
1030 오라클에서 큐브리드 to_DATETIME 질문요 .. ㅠㅠ 5 kks 2019.02.26 1207
1029 CUBRID DB 날짜 및 시간 변환 하는 방법 알려주시면 감사하겠습니다. 1 루이지 2019.02.28 1219
1028 큐브리드 매니저에 테이블 목록이 안보입니다. 1 file 배여사남편 2019.03.08 230
1027 cubrid-node 쿼리 응답 없음 1 바삭상자 2019.03.08 164
1026 Spring Boot 큐브리드 select 경우 에러발생 문의드립니다. 1 피닉스맨 2019.03.11 2014
1025 Java VM is not running 오류 문의드립니다 4 Kim 2019.03.12 1572
1024 질문이 있습니다. 4 bjosbkjx 2019.03.14 379
1023 CUBRID 복구시 테이블 복구 안되는 문제 1 다며 2019.03.15 214
1022 데이터베이스 목록이 보이지 않음 3 file 뀨쀼리뜨 2019.03.20 271
1021 특수문자 깨짐 1 어려워 2019.03.21 1169
1020 REPLACE 함수 문의 1 아범 2019.03.22 1750
1019 테이블생성 494 실행오류 문의 1 뺀돌스 2019.03.25 1260
1018 릴리즈된 ADO.NET 드라이버를 다운받을수 없습니다. 4 모비23 2019.03.27 111
1017 CUBRID DB 날짜 및 시간을 타임스탬프 형식으로 변환 하는 방법 알려주시면 감사하겠습니다. 3 루이지 2019.04.01 674
Board Pagination Prev 1 ... 143 144 145 146 147 148 149 150 151 152 ... 199 Next
/ 199

Contact Cubrid

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