0

これは私のストアドプロシージャです:

SET TERM ^ ;
CREATE PROCEDURE INSERT_ETYPE (
    E_ID Integer,
    E_NAME Varchar(20) CHARACTER SET NONE )
RETURNS (
    NEW_ID Integer)
AS
declare variable addr varchar(20);
declare variable type smallint;
declare variable ord smallint;
declare variable cmd varchar(255);
declare variable answr varchar(255);
begin
  insert into ETYPE
  select * from ETYPE where ID=:e_id;
  select max(ID) from ETYPE into :new_id;

  update ETYPE set NAME = :e_name where ID = :new_id;
  for 
    select ADDR,REGTYPE,ORD from ETYPEREGS 
      where ETYPE_ID=:e_id
      into :addr,:type,:ord
    do
      begin
        insert into ETYPEREGS
          (ETYPE_ID,ADDR,REGTYPE,ORD)
         values
          (:new_id,:addr,:type,:ord);
      end 
  for 
    select CMD,ANSWR,ORD,REGTYPE from ETYPESPECIAL 
      where ETYPE_ID=:e_id
      into :cmd,:answr,:ord,:type
    do
      begin
        insert into ETYPESPECIAL
          (ETYPE_ID,CMD,ANSWR,ORD,REGTYPE)
         values
          (:new_id,:cmd,:answr,:ord,:type);
      end
end^
SET TERM ; ^

これは C++ での私のコードです:

StoredProc_InsertEType->ParamByName("E_ID")->AsInteger = src_id;
StoredProc_InsertEType->ParamByName("E_NAME")->AsString = _name;
try
{
 StoredProc_InsertEType->ExecProc();
 new_id = StoredProc_InsertEType->ParamByName(L"NEW_ID")->AsInteger;
}
catch(EDBEngineError & e)
{
 errors->Add(e.Message);
 return false;
}

テーブル ETYPE が空でないにもかかわらず、変数 new_id は常にゼロです。管理ツールの FlameRobin からコマンドを実行するとSELECT MAX(ID) FROM ETYPE、正しい番号 (~180) が返されます。NEW_ID パラメータの正しい値を取得するにはどうすればよいですか?

4

1 に答える 1

2

追加する必要があります

suspend;

あなたのspで

とクエリ

select * from your_sp

説明を一時停止 http://www.janus-software.com/fbmanual/manual.php?book=psql&topic=104

よろしく、

于 2012-09-25T11:53:03.210 に答える