C++Builder Programming Forum
C++Builder  |  Delphi  |  FireMonkey  |  C/C++  |  Free Pascal  |  Firebird
볼랜드포럼 BorlandForum
 경고! 게시물 작성자의 사전 허락없는 메일주소 추출행위 절대 금지
C++빌더 포럼
Q & A
FAQ
팁&트릭
강좌/문서
자료실
컴포넌트/라이브러리
메신저 프로젝트
볼랜드포럼 홈
헤드라인 뉴스
IT 뉴스
공지사항
자유게시판
해피 브레이크
공동 프로젝트
구인/구직
회원 장터
건의사항
운영진 게시판
회원 메뉴
북마크
볼랜드포럼 광고 모집

C++빌더 Q&A
C++Builder Programming Q&A
[36469] 급합니다.. 오라클 다뤄 보신 분.. Y_Y
DoyongID [doyongid] 931 읽음    2004-07-24 08:50
테이블의 목록을 받아와서 처리하는 작업을 하려고 하는데요..

일단, 직접 SQL문을 보내니깐 받아지기는 합니다..

lpADOCommand->CommandText       = "Select Inx, Price From ItemSet";
lpADOCommand->ExecuteOptions    = TExecuteOptions();
lpADODataSet->Recordset         = lpADOCommand[pIndex]->Execute();

근데, 저는 오라클에 있는 저장프로시져를 이용해서 값을 받고 싶거든요.. 그런데, 저장프로시져를
작성했는데, 오라클은 select문의 결과값이 2개이상 나오면 짜면 에러가 난다고 하더군요.. (왜 그런지. -.-)
그래서 커서라던가 뭐 그런거 써서 되게 만들었는데, 그냥 이렇게 뿌려주기만하면 ADO에서 알아서 Inx, Price값을 구분해서 받는건 아닌것 같습니다.

오라클에서 저장프로시져상에서 select문의 결과 리스트를 보내려면 어떻게 짜야하는건가요?
제가 짠 저장 프로시져는 아래와 같습니다..

Create Or Replace Procedure GetItemSet As
pInx ItemSet.Inx%type;
pPrice ItemSet.Price%type;

Cursor C_ITEM Is
Select Inx, Price
From ItemSet;

Begin

Open C_ITEM;
Loop
Fetch C_ITEM Into pInx, pPrice;
Exit When C_ITEM%NOTFOUND;

DBMS_OUTPUT.PUT_LINE(pInx||' '||pPrice);

Commit;
End Loop ;
Close C_ITEM;

End GetItemSet;
/
exec GetItemSet;

제가 MS-SQL을 쓸때는 ADOCommand를 써서 프로시져를 실행했는데, 오라클에서는 ADOStoredProc로 실행해야 하는건 아니죠??

+ -

관련 글 리스트
36469 급합니다.. 오라클 다뤄 보신 분.. Y_Y DoyongID 931 2004/07/24
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.