PHP.nl

pg_send_query

pg_send_query

Sends asynchronous query

 **pg_send_query** PgSql\Connection $connection string $query
sends a query or queries asynchronously to the

. Unlike , it can send multiple queries at once to PostgreSQL and get the results one by one using . pg_send_query``connection``pg_query``pg_get_result

Script execution is not blocked while the queries are executing. Use to check if the connection is busy (i.e. the query is executing). Queries may be cancelled using . pg_connection_busy``pg_cancel_query

Although the user can send multiple queries at once, multiple queries cannot be sent over a busy connection. If a query is sent while the connection is busy, it waits until the last query is finished and discards all its results.

connection``queryThe SQL statement or statements to be executed.

   Data inside the query should be .
  properly escaped

Returns true on success, false or on failure. Use to determine the query result. 0``pg_get_result

Voorbeeld: example

<?php
  $dbconn = pg_connect("dbname=publisher") or die("Could not connect");

  if (!pg_connection_busy($dbconn)) {
      pg_send_query($dbconn, "select * from authors; select count(*) from authors;");
  }
  
  $res1 = pg_get_result($dbconn);
  echo "First call to pg_get_result(): $res1\n";
  $rows1 = pg_num_rows($res1);
  echo "$res1 has $rows1 records\n\n";
  
  $res2 = pg_get_result($dbconn);
  echo "Second call to pg_get_result(): $res2\n";
  $rows2 = pg_num_rows($res2);
  echo "$res2 has $rows2 records\n";
?>
First call to pg_get_result(): Resource id #3
Resource id #3 has 3 records

Second call to pg_get_result(): Resource id #4
Resource id #4 has 1 records

pg_query``pg_cancel_query``pg_get_result``pg_connection_busy