Geting:警告:oci_fetch():ORA-24374:在获取或执行和获取之前定义未完成。尽管已经定义了名称

时间:2015-07-07 15:53:52

标签: php database oracle oci

在阅读了我能找到的每本手册之后,我仍然无法找到解决这个问题的方法。

我有以下代码:

<?php

$token = 'number';
$secret = 'number';
$ID;

$conn = oci_connect('FITBIT', 'pass', '127.0.0.1/xe');
$stid = oci_parse($conn, 'BEGIN find_personsdevice_id(:token, :secret, :l_personsdeviceid); END;');
oci_bind_by_name($stid, ':token', $token);
oci_bind_by_name($stid, ':secret', $secret);
oci_bind_by_name($stid, ':l_personsdeviceid', $ID);

oci_define_by_name($stid, 'l_personsdeviceid', $ID);
oci_define_by_name($stid, ':token,', $token);
oci_define_by_name($stid, ':secret,', $secret);

oci_execute($stid);
oci_fetch($stid);
var_dump($stid);

?>

该过程正在运行,我使用sql developer对其进行了测试,并给出了正确的结果。但是当我尝试在这个PHP脚本中调用它时,我收到以下消息:

警告:oci_fetch():ORA-24374:在获取或执行之前定义未完成并在

中获取

我搜索了ora代码,发现了这个:

原因:应用程序未定义 在发出提取调用之前获取的数据的输出变量 通过在执行调用中指定非零行计数来调用获取。 行动:发布OCI定义调用 要获取的列。

据我所知,我把oci_fetch命令放在define命令之后。那么我做错了什么?

PL / SQL程序:

create or replace
procedure find_personsdevice_id(b_token in varchar2, b_secret in varchar2, l_personsdeviceid out number) as

/*author Ruben Jonkers
  project: FITBIT
  goal procedure: find ID by token and seccret
  date: 20-05-2015
  version:0.1
  adjustments:
*/


cursor c_personsdeviceid (b_token in varchar2:='', b_secret in varchar2:='') is
  select pde.id 
  from personsdevices pde,
       persons psn,
       groups grp,
       tokens tns
  where psn.id=pde.persons_id
  and pde.persons_id = psn.id
  and grp.tokens_id = tns.id
  and tns.token = b_token
  and tns.secret = b_secret;

  r_personsdeviceid c_personsdeviceid%rowtype;

begin
  open c_personsdeviceid (b_token, 
                          b_secret);
  fetch c_personsdeviceid into r_personsdeviceid;
    if c_personsdeviceid%found then
      l_personsdeviceid:=r_personsdeviceid.id;
    end if;
  close c_personsdeviceid;

end;

2 个答案:

答案 0 :(得分:0)

原来我根本不需要oci_fetch,因为结果已经存储在$ id中了!

答案 1 :(得分:0)

消除 oci_fetch() 调用实际上并没有解决最初为什么会出现此错误的问题。此处的实际错误和说明 ORA-24374: define not done before fetch 似乎不正确,因为您的代码似乎确实定义了所有参数。

一个原因是你的过程只返回一个输出参数;它不会产生一组 oci_fetch() 正在寻找的行,这些行通常在循环中调用。当您不需要 fetch 时,您也不需要 oci_define_by_name() 调用。但我不知道为什么会产生如此无意义和误导性的错误。

另一种可能是驱动程序或数据库错误。您在 /*...*/ 中的多行注释可能是 triggering it。您应该使用 -- 作为解决方法将该块转换为单行注释。确切的数据库版本也与此处相关。