(PHP 5 >= 5.3.0, PHP 7)
mysqli::poll -- mysqli_poll — 接続を問い合わせる
オブジェクト指向型
&$read
, array &$error
, array &$reject
, int $sec
[, int $usec
] ) : int手続き型
&$read
, array &$error
, array &$reject
, int $sec
[, int $usec
] ) : int
read
読み込める結果が残っている接続のリスト。
error
クエリが失敗した、あるいは接続が切断されたなどのエラーが発生した接続のリスト。
reject
関数から結果を取得できるような非同期クエリが実行されていないという理由で、 拒否された接続のリスト。
sec
待ち続ける秒数の最大。非負の数でなければなりません。
usec
待ち続けるマイクロ秒数の最大。非負の数でなければなりません。
成功した場合に使用できる接続の数、それ以外の場合に FALSE
を返します。
例1 mysqli_poll() の例
<?php
$link1 = mysqli_connect();
$link1->query("SELECT 'test'", MYSQLI_ASYNC);
$all_links = array($link1);
$processed = 0;
do {
$links = $errors = $reject = array();
foreach ($all_links as $link) {
$links[] = $errors[] = $reject[] = $link;
}
if (!mysqli_poll($links, $errors, $reject, 1)) {
continue;
}
foreach ($links as $link) {
if ($result = $link->reap_async_query()) {
print_r($result->fetch_row());
if (is_object($result))
mysqli_free_result($result);
} else die(sprintf("MySQLi Error: %s", mysqli_error($link)));
$processed++;
}
} while ($processed < count($all_links));
?>
上の例の出力は以下となります。
Array ( [0] => test )