PHP:多个SQL语句


PHP: Multiple SQL Statements

我有一个SQL查询,如下所示:

$sql = "SELECT * FROM TABLE ... 
INSERT ...
DELETE ...";

并且我希望在查询Oracle数据库时使用多个语句。我知道在mySQL中有mysqli_multi_query()。这在Oracle中可能吗?

谢谢。

摘自:使用PHP和Oracle数据库12c隐式结果集

新的Oracle数据库12c"隐式结果集"(IRS)功能允许从存储的PL/SQL过程(或PL/SQL匿名块)返回查询结果,而不需要特殊的PHP代码。当编译IRS并与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调用它。