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.
Exemplo 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().