Background Image

FORUM

2009.12.23 02:13

BLOB 데이터 select 질문

조회 수 12078 추천 수 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 2019.07.31 323
126 C-API 매뉴얼 위치요? 1 그래너 2010.01.11 9834
125 C++(MFC 아님)에서 프로그래밍 작성을 하려면 어떤것을 사용해야 하나요? 6 나동호 2009.03.24 19920
124 C++ Embedded SQL에서 호스트 변수로 클래스 데이터 선언 가능 여부 문의 1 리겔 2012.04.20 9901
123 C#에서 한글컬럼명이 깨지는 증상 4 미르 2013.11.05 19155
122 C#에서 ODBC연결시 에러 1 용이 2009.11.15 31628
121 C# ole db 연동 오류 어떻게 해야 할지 조언 부탁 드립니다. 4 배나와사마 2013.02.28 14879
120 C# WPF Dataset 연결시 외래키 자동 연결 안됨. 1 moon 2014.07.11 9811
119 C# ADO.NET 이용했을떄 문제 1 보람이 2017.04.14 8031
118 Broker 에러가 자주 납니다. 1 아르게네스 2010.11.17 7285
117 Broker log 에 start 만 찍히는건 어떤 현상인가요 3 노스 2010.08.24 9070
116 BeginTrans 상태에서 검색 시 응답없음 발생 7 까망이 2011.04.22 14624
115 BLOB에 대한 자바 타입변환 문제.. 1 file ㅇㅇ 2013.01.28 9885
114 BLOB 타입 이미지를 JSP로 웹에 뿌려주려면 어떻게 해야하나요? 1 아워나 2014.07.07 13991
» BLOB 데이터 select 질문 1 hyperhand 2009.12.23 12078
112 BIT형 데이터에 대한 where ... IN 쿼리 1 소라게 2010.03.10 10725
111 A트랜잭션에서 Update중인 row 를 B트랜잭션에서 Select 1 큐불리드 2015.12.25 5928
110 Auto Increment에 대한 질문입니다. 3 너랑이마녀 2016.02.18 7876
109 Audit 테이블 따로 존재하나요? 3 JIRAN 2019.07.01 37
108 Attempt to call a method related to scrollability of non-scrollable ResultSet. 오류 문의 1 cuins 2011.07.28 12448
107 Archive log 관리 질문 2 june2 2013.07.16 8988
Board Pagination Prev 1 ... 143 144 145 146 147 148 149 150 151 152 ... 154 Next
/ 154

Contact Cubrid

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