PHP:多个SQL语句

时间:2013-11-22 22:10:39

标签: php sql oracle

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

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

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

谢谢。

1 个答案:

答案 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调用它。