說明
bool
pg_send_query ( resource connection, string query )
bool
pg_send_query ( string query )
pg_send_query() 向 connection
連線傳送異步查詢。和 pg_query() 不同,它可以向 PostgreSQL
傳送多個查詢並用 pg_get_result()
依次得到結果。當執行查詢時腳本的執行不會被鎖定。用
pg_connection_busy() 來檢查連線連線是否為忙(即查詢正在執行中)。呼叫
pg_cancel_query() 則有可能取消查詢。
儘管會員可以一次傳送多個查詢,但會員不能通過忙線中的連線傳送多個查詢。若果向忙線中的連線傳送了查詢,則會等待上一筆查詢結束並丟棄所有結果。
例子 1. 異步查詢
<?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()。