小编Som*_*uck的帖子

可以使用 PDO 和 PostgreSQL 返回多个结果集吗?

我想将多个查询分组到 PostgreSQL 中的一个函数中。将使用 PDO 查询该函数。

其功能是:

CREATE OR REPLACE FUNCTION "test_multipe_refcursor"() 
RETURNS SETOF refcursor AS $BODY$

DECLARE
    parentRC refcursor;
    childRC refcursor;

BEGIN

open parentRC FOR
SELECT * FROM parent;
RETURN NEXT parentRC;

open childRC FOR
SELECT * FROM child;
RETURN NEXT childRC;

RETURN;

END;$BODY$
LANGUAGE 'plpgsql' VOLATILE;

ALTER FUNCTION "test_multipe_refcursor"() OWNER TO postgres;
Run Code Online (Sandbox Code Playgroud)

这是 PHP 代码。“Database”作为一个单例类,设置通常的连接属性,没有什么特别的。

  $database = Database::load();
  $sql = "select * from test_multipe_refcursor();";
  $p = $database->query($sql);

  $i = 1;
  do
  {
     $this->set('set' . $i, $p->fetchAll(PDO::FETCH_ASSOC));
     $i++;
  } while …
Run Code Online (Sandbox Code Playgroud)

php postgresql pdo

5
推荐指数
1
解决办法
2536
查看次数

标签 统计

pdo ×1

php ×1

postgresql ×1