带参数的PHP-OCI调用存储过程

时间:2015-03-12 06:13:37

标签: php oracle stored-procedures oci

存储过程:

parentchildhrs number(7,0);
childhours number(7,0);

begin

COMBINED_HOURS(122,parentchildhrs,childhours);

end;

上述通过Oracle SQL Developer执行时输出正确的预期值,即小时数。输出

CHILD HOURS 50
parent task id 122
parentchild HOURS 100

现在,当我使用PHP-OCI调用时,它什么都不输出。

$taskID = 122;
$parent_hours = '';
$child_hours = '';
$procedure = "BEGIN TASK_COMBINED_CHILD_HRS(:task_id, :parent_child_hours, :child_hours); END;";
$test = $taskmaster->getHours($procedure, [':task_id' => $taskID,':parent_child_hours' => (int)$sum_parent_child_hours,':child_hours' => (int)$sum_child_hours]);



    public function getHours($query, $params){
           $result_hours = parent::ocibindbyname($query, $params);
           return $result_hours;
    }

public static function customquery($query, $params)
{

  try{  

      $stmt = oci_parse($conn, $query);
      foreach ($params as $key => &$value) {              
        oci_bind_by_name($stmt, $key, $value, 32);
      }
      oci_execute($stmt,OCI_COMMIT_ON_SUCCESS);
      oci_commit($conn);
      oci_free_statement($stmt);
      return $params;
      }catch (Exception  $e){
        print_r($e);
    }               
}

打印结果

Array
(
    [:task_id] => 1142
    [:parent_child_hours] => 100
    [:child_hours] => 50
)
  1. 如何将parent_child_hourschild_hours的PHP变量绑定为存储过程变量的输出?

1 个答案:

答案 0 :(得分:0)

在处理存储过程时,使用foreach方法从my answer到另一个问题并不是一个好主意。

虽然它确实有效(如你的问题所示,变量在执行后在$params数组中设置),但最大的问题是你必须提供第四个参数(maxlength)到{{ 1}}。您在代码中使用了oci_bind_by_name的静态值,但是当值的长度超过此值时会引发错误。它无法在运行时计算并将其设置为非常大的值是低效的(可能这对您的应用程序来说不是问题)。

由于您正在运行已知的存储过程,因此您应该在设计时知道输出值的32,并且可以通过将所有maxlength函数放在oci_*中来静态输入这些值,而不是试图抽象所有对getHours()的调用。