PHP/OCI - 无法从临时 table 中的 Oracle 过程获取结果
PHP/OCI - Unable to get results from Oracle procedure within a temporary table
我正在尝试使用 PHP OCI Oracle 函数做两件事:
- 运行 Oracle 数据库中的包过程。
- 一旦包有 运行,查询一个临时的 table 以获得程序运行的结果。
我能够使用 Oracle 提供的 SQL 开发人员软件成功完成此操作。我的查询非常基础,如下所示:
BEGIN
PKG_KTY_SEARCH.PR_PRICE_LIST();
END;
/
SELECT * FROM kty_web.KTY_PROD_PRICE_TEMP;
上面的代码完美运行,我在 SQL Developer 中得到了完整的 table 结果。
我正在尝试使用 OCI 在 PHP 中做同样的事情。我的代码如下所示:
<?php
// Load up the system.
require('../../system/init.php');
global $config;
$oracleDb = oci_new_connect($config['oracleDb']['username'], $config['oracleDb']['password'], $config['oracleDb']['connectionString']);
$firstStid = oci_parse($oracleDb, "BEGIN PKG_KTY_SEARCH.PR_PRICE_LIST(); END;");
oci_execute($firstStid);
$secondStid = oci_parse($oracleDb, "SELECT * FROM kty_web.KTY_PROD_PRICE_TEMP");
oci_execute($secondStid);
oci_fetch_all($secondStid, $result);
echo json_encode($result);
echo "<br />Import complete!";
?>
然而 returns 没有错误,结果集为空。我不知道为什么。有人在这里看到我遗漏的任何明显信息吗?
从PHP
返回的结果集
{"PRODUCT_ID":[],"CUST_ROLE":[],"MIN_QTY":[],"MAX_QTY":[],"PRICE":[]}
我的连接字符串如下:
$config['oracleDb']['connectionString'] = "(DESCRIPTION=(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = " . $config['oracleDb']['host'] . ")(PORT = " . $config['oracleDb']['port'] . ")))(CONNECT_DATA=(SID=" . $config['oracleDb']['sid'] . ")))";
我正在使用 PHP7.1.22 和 Oracle 11g 数据库。我能够查询正常的 tables 并在 PHP 内毫无问题地获得结果并获得完整的结果集。
临时table定义为on commit delete rows
还是on commit preserve rows
?
默认情况下,oci_execute
将在每次成功调用后隐式发出 commit
。假设您的临时 table 定义为 on commit delete rows
,这将删除后续查询之前的行。您可以通过传递可选的第二个参数
来更改该行为
oci_execute($firstStid, OCI_DEFAULT);
但是,假设您这样做,您将需要明确 oci_commit
以关闭您打开的交易。
我正在尝试使用 PHP OCI Oracle 函数做两件事:
- 运行 Oracle 数据库中的包过程。
- 一旦包有 运行,查询一个临时的 table 以获得程序运行的结果。
我能够使用 Oracle 提供的 SQL 开发人员软件成功完成此操作。我的查询非常基础,如下所示:
BEGIN
PKG_KTY_SEARCH.PR_PRICE_LIST();
END;
/
SELECT * FROM kty_web.KTY_PROD_PRICE_TEMP;
上面的代码完美运行,我在 SQL Developer 中得到了完整的 table 结果。
我正在尝试使用 OCI 在 PHP 中做同样的事情。我的代码如下所示:
<?php
// Load up the system.
require('../../system/init.php');
global $config;
$oracleDb = oci_new_connect($config['oracleDb']['username'], $config['oracleDb']['password'], $config['oracleDb']['connectionString']);
$firstStid = oci_parse($oracleDb, "BEGIN PKG_KTY_SEARCH.PR_PRICE_LIST(); END;");
oci_execute($firstStid);
$secondStid = oci_parse($oracleDb, "SELECT * FROM kty_web.KTY_PROD_PRICE_TEMP");
oci_execute($secondStid);
oci_fetch_all($secondStid, $result);
echo json_encode($result);
echo "<br />Import complete!";
?>
然而 returns 没有错误,结果集为空。我不知道为什么。有人在这里看到我遗漏的任何明显信息吗?
从PHP
返回的结果集{"PRODUCT_ID":[],"CUST_ROLE":[],"MIN_QTY":[],"MAX_QTY":[],"PRICE":[]}
我的连接字符串如下:
$config['oracleDb']['connectionString'] = "(DESCRIPTION=(ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = " . $config['oracleDb']['host'] . ")(PORT = " . $config['oracleDb']['port'] . ")))(CONNECT_DATA=(SID=" . $config['oracleDb']['sid'] . ")))";
我正在使用 PHP7.1.22 和 Oracle 11g 数据库。我能够查询正常的 tables 并在 PHP 内毫无问题地获得结果并获得完整的结果集。
临时table定义为on commit delete rows
还是on commit preserve rows
?
默认情况下,oci_execute
将在每次成功调用后隐式发出 commit
。假设您的临时 table 定义为 on commit delete rows
,这将删除后续查询之前的行。您可以通过传递可选的第二个参数
oci_execute($firstStid, OCI_DEFAULT);
但是,假设您这样做,您将需要明确 oci_commit
以关闭您打开的交易。