Forum und email

pg_send_query

(PHP 4 >= 4.2.0, PHP 5)

pg_send_query — Envia uma consulta (query) assincrona

Descrição

bool pg_send_query ( resource $connection , string $query )
bool pg_send_query ( string $query )

pg_send_query() envia uma consulta (query) assíncrona para connection . Diferente de pg_query(), ela pode enviar consultas múltiplas para o PostgreSQL e carregar os resultados, um por um, usando pg_get_result(). A execução do script não é bloqueada enquanto as consultas estão sendo executadas. Use pg_connection_busy() para checar se a conexão está ocupada. (por exemplo, se uma consulta está sendo executada). A consulta pode ser cancelada chamando pg_cancel_query().

Apesar de ser possível enviar multiplas consultas de uma vez, você não pode enviar múltiplas consultas para uma conexão ocupada. Se a consulta é enviada enquando a conexão está ocupada ela espera até que a última cosulta seja finalizada e descarta todos os resultados.

Example#1 Asynchronous Queries

<?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";
?>

O exemplo acima deve mostrar a seguinte saída:

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

Veja também pg_query(), pg_cancel_query(), pg_get_result() e pg_connection_busy().