我有一个SQL查询,如下所示:
$sql = "SELECT * FROM TABLE ...
INSERT ...
DELETE ...";
我想在查询Oracle数据库时使用多个语句。我知道在mySQL中有mysqli_multi_query()。这可能在Oracle吗?
谢谢。
答案 0 :(得分:0)
取自:Using PHP and Oracle Database 12c Implicit Result Sets
新的Oracle Database 12c“隐式结果集”(IRS)功能允许从存储的PL / SQL过程(或PL / SQL匿名块)返回查询结果,而无需特殊的PHP代码。在编译并与Oracle Database 12c一起使用时,PHP的OCI8 2.0.0-devel扩展中提供对IRS的支持。 (OCI8 2.0可以编译并与其他版本的Oracle数据库一起使用,但可用的功能集减少了。)
<?php
$c = oci_connect('hr', 'welcome', 'localhost/pdborcl');
$sql =
"declare
c1 sys_refcursor;
begin
open c1 for select city from locations where rownum < 4;
dbms_sql.return_result(c1);
open c1 for select first_name, last_name from employees where rownum < 4;
dbms_sql.return_result(c1);
end;";
$s = oci_parse($c, $sql);
oci_execute($s);
while (($s2 = oci_get_implicit_resultset($s))) {
// Now treat $s2 as a distinct query statement resource
$ncols = oci_num_fields($s2);
for ($i = 1; $i <= $ncols; ++$i) {
$colname = oci_field_name($s2, $i);
echo $colname . " ";
}
echo "\n";
while (($row = oci_fetch_row($s2)) != false) {
foreach ($row as $item) {
echo $item . " ";
}
echo "\n";
}
}
?>
或者,您可以在Oracle中创建存储过程(可以包含多个语句和输出参数),然后从PHP调用它。