(PHP 5, PHP 7, PHP 8)
mysqli_stmt::$error -- mysqli_stmt_error — 直近のステートメントのエラー内容を文字列で返す
オブジェクト指向型
手続き型
直近に実行されたステートメントが 成功あるいは失敗した際のエラーメッセージを文字列で返します。
stmt
手続き型のみ: mysqli_stmt_init() が返す mysqli_stmt オブジェクト。
エラーの内容を文字列で返します。エラーが発生しなかった場合は空文字列を返します。
例1 オブジェクト指向型
<?php
$mysqli = new mysqli("localhost", "my_user", "my_password", "world");
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
$mysqli->query("CREATE TABLE myCountry LIKE Country");
$mysqli->query("INSERT INTO myCountry SELECT * FROM Country");
$query = "SELECT Name, Code FROM myCountry ORDER BY Name";
if ($stmt = $mysqli->prepare($query)) {
$mysqli->query("DROP TABLE myCountry");
$stmt->execute();
printf("Error: %s.\n", $stmt->error);
$stmt->close();
}
$mysqli->close();
?>
例2 手続き型
<?php
$link = mysqli_connect("localhost", "my_user", "my_password", "world");
if (mysqli_connect_errno()) {
printf("Connect failed: %s\n", mysqli_connect_error());
exit();
}
mysqli_query($link, "CREATE TABLE myCountry LIKE Country");
mysqli_query($link, "INSERT INTO myCountry SELECT * FROM Country");
$query = "SELECT Name, Code FROM myCountry ORDER BY Name";
if ($stmt = mysqli_prepare($link, $query)) {
mysqli_query($link, "DROP TABLE myCountry");
mysqli_stmt_execute($stmt);
printf("Error: %s.\n", mysqli_stmt_error($stmt));
mysqli_stmt_close($stmt);
}
mysqli_close($link);
?>
上の例の出力は以下となります。
Error: Table 'world.myCountry' doesn't exist.