Возможно, вам лучше вызывать хранимую процедуру напрямую через PHP / OCI, чем пытаться сделать это через PL / SQL-запрос:
$stid = oci_parse($c, "call apps.xx_ar_cust_os_bal_pkg.xx_ar_cust_os_bal_proc('34499', NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL)");
oci_execute($stid);
Если вам нужно вернуть результаты хранимой процедуры, вам нужно использовать переменные связывания:
$stid = oci_parse($c, "call apps.xx_ar_cust_os_bal_pkg.xx_ar_cust_os_bal_proc('34499', :inv_num, :unit_no, :cust_name, :inv_date, :trans_type, :cust_no, :outstanding_amount, :err)");
/* Do this for each bind variable */
oci_bind_by_name($stid, ":inv_num", $inv_num);
...
oci_execute($stid);
РЕДАКТИРОВАТЬ: Передача параметра P_INV_NUMBER
в качестве переменной связывания:
$stid = oci_parse($c, "call apps.xx_ar_cust_os_bal_pkg.xx_ar_cust_os_bal_proc(:inv_number, :inv_num, :unit_no, :cust_name, :inv_date, :trans_type, :cust_no, :outstanding_amount, :err)");
oci_bind_by_name($stid, ":inv_number", "34499");
/* Do this for each bind variable */
oci_bind_by_name($stid, ":inv_num", $inv_num);
...
oci_execute($stid);
Надеюсь, это поможет.