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
[36501] ADOStoredProc에서 에러...
DoyongID [doyongid] 1871 읽음    2004-07-26 23:42
답변주시는 분이 거의... 없지만, 오기로 계속 올려보겠습니다. -.-


오라클의 저장 프로시져는 아래와 같습니다. 인자로 받은 pID값이 테이블에 존재하면 1, 없으면 0를 리턴하는 역할을 합니다..

그런데, ADO로 프로시져를 실행하면 CommandText does not return a result set. 라는 에러창이 뜹니다..

create or replace procedure IsAccount(pID IN UserPersonalInfo.ID%type, pCount OUT Number) AS
begin
Select Inx
Into pCount
From UserPersonalInfo
Where ID = pID;
Exception
when NO_DATA_FOUND then
pCount := 0;
End IsAccount;

ADO로 짠 소스는 아래와 같습니다..
lpADOProc->ProcedureName    = "IsAccount";
lpADOProc->Parameters->Clear();
lpADOProc->Parameters->CreateParameter("pID", ftString, pdInput, 8, NULL);
lpADOProc->Parameters->CreateParameter("pCount", ftInteger, pdOutput, 4, NULL);
lpADOProc->Parameters->ParamByName("pID")->Value   = pID;

lpADOProc->ExecProc();
lpADOProc->Active = true; // ### 여기서 CommandText does not return a result set. 에러 발생 ###

if(lpADOProc->RecordCount != 1)
{
   lpADOProc->Active = false;
   return false;
}

lpADOProc->Active = false;

return true;

그리고, 한가지 더 궁금한게 CreateParameter에서 준 pdOutput을 넣으면 저장프로시져로부터 값을 리턴받는걸로 아는데, 어떻게 값을 받아내는거죠?

+ -

관련 글 리스트
36501 ADOStoredProc에서 에러... DoyongID 1871 2004/07/26
Google
Copyright © 1999-2015, borlandforum.com. All right reserved.