mysqli::kill
mysqli_kill
サーバーに MySQL スレッドの停止を問い合わせる
警告この関数は PHP 8.4.0 で
非推奨になります。この関数に頼らないことを強く推奨します。
説明
オブジェクト指向型
public bool mysqli::kill(int $process_id
)
bool mysqli_kill(mysqli $mysql
, int $process_id
)
実行中のクエリを停止するには、SQL コマンド
KILL QUERY processid
を使用する必要があります。
パラメータ
-
link
-
手続き型のみ:
mysqli_connect あるいは mysqli_init が返す mysqliオブジェクト。
戻り値
成功した場合に true
を、失敗した場合に false
を返します。
エラー / 例外
mysqli のエラー報告 (MYSQLI_REPORT_ERROR
) が有効になっており、かつ要求された操作が失敗した場合は、警告が発生します。さらに、エラー報告のモードが MYSQLI_REPORT_STRICT
に設定されていた場合は、mysqli_sql_exception が代わりにスローされます。
例
例1 mysqli::kill の例
<?php
$mysqli = new mysqli("localhost", "my_user", "my_password", "world");
/* 接続状況をチェックします */
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
/* スレッド ID を取得します */
$thread_id = $mysqli->thread_id;
/* 接続を終了します */
$mysqli->kill($thread_id);
/* これはエラーとなります */
if (!$mysqli->query("CREATE TABLE myCity LIKE City")) {
printf("Error: %s\n", $mysqli->error);
exit;
}
/* 接続を閉じます */
$mysqli->close();
?>
<?php
$link = mysqli_connect("localhost", "my_user", "my_password", "world");
/* 接続状況をチェックします */
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
/* スレッド ID を取得します */
$thread_id = mysqli_thread_id($link);
/* 接続を終了します */
mysqli_kill($link, $thread_id);
/* これはエラーとなります */
if (!mysqli_query($link, "CREATE TABLE myCity LIKE City")) {
printf("Error: %s\n", mysqli_error($link));
exit;
}
/* 接続を閉じます */
mysqli_close($link);
?>
Error: MySQL server has gone away