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 48
공지 SQLGate for CUBRID 영구 무료 라이선스 제공 file admin 2020.04.09 4458
994 아카이브 로그 정리 관련 6 기마누엘 2019.06.20 460
993 json 데이터타입 insert/update 1 임소현 2019.06.24 1417
992 DBA 권한 부여 방법 설명해주세요. 1 JIRAN 2019.07.01 1290
991 COMMMENT 추가 방법 좀 알려주십시오. 3 허접 2019.07.01 1213
990 Audit 테이블 따로 존재하나요? 3 JIRAN 2019.07.01 242
989 날짜 데이터 변환 1 옐인 2019.07.03 547
988 cannot fetch serial object 2 file happyday0393 2019.07.04 196
987 큐브리드 서비스 멈춘 뒤 DB 덮어씌기 후 서비스 재시작이 안되는 경우 1 민수킴 2019.07.08 167
986 큐브리드 매니저가 다운되지 않습니다. 1 퓨전남 2019.07.08 141
985 테이블명 대문자 문의드립니다. 1 jechoi 2019.07.09 621
984 cannot fetch serial object 두번째 문의 3 happyday0393 2019.07.09 216
983 DB table 별 용량 확인방법 문의합니다. 3 톨톨 2019.07.10 1475
982 프로시저와 함수 관련 질문이 있습니다... 1 bjosbkjx 2019.07.11 239
981 Mac mojave 버전 큐브리드 설치 문제 1 norman 2019.07.18 303
980 시점복구 왜 안될까요?? 1 kubrid 2019.07.20 256
979 예약어 관련하여 문의드립니다. 1 jechoi 2019.07.23 151
978 select문 실행시 칼럼명 구분콤마( , )가 없을때, 앞 칼럼의 데이터가 뒤 칼럼명의 데이터로 나오는 현상 2 유진욱 2019.07.23 429
977 JOIN (+)과 함수 에러 3 wewek3jk3 2019.07.24 260
976 큐브리드 매니저 툴(Mac Mojave) 편집 화면에서 쿼리 작성 시 키 타이핑 속도 못따라갈정도로 느린 이슈 2 norman 2019.07.24 388
975 큐브리드 매니저 가져오기 기능 오류 1 file 장두 2019.07.25 316
Board Pagination Prev 1 ... 146 147 148 149 150 151 152 153 154 155 ... 200 Next
/ 200

Contact Cubrid

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