mysqli_stmt::$sqlstate
mysqli_stmt_sqlstate
(PHP 5, PHP 7)
mysqli_stmt::$sqlstate -- mysqli_stmt_sqlstate — 直前のステートメントの操作での SQLSTATE エラーを返す
説明
オブジェクト指向型
string $mysqli_stmt->sqlstate
;
手続き型
mysqli_stmt_sqlstate
( mysqli_stmt $stmt
) : string
直近に実行されたプリペアドステートメントのエラーについて、
SQLSTATE エラーコードを含む文字列を返します。
エラーコードは 5 つの文字で構成されています。'00000'
はエラーが発生しなかったことを意味します。この値は、ANSI SQL および
ODBC で定義されています。とりうる値の一覧は
» http://dev.mysql.com/doc/mysql/en/error-handling.html
を参照ください。
返り値
直前のエラーに関する SQLSTATE エラーコードを含む文字列を返します。
エラーコードは 5 文字で構成され、'00000'
はエラーが発生しなかったことを意味します。
注意
注意:
すべての MySQL エラーが SQLSTATE に対応しているわけではないことに 注意してください。そのようなエラーが発生した場合は、
HY000
(一般的なエラー)が返されます。
例
例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->sqlstate); /* ステートメントを閉じます */ $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_sqlstate($stmt)); /* ステートメントを閉じます */ mysqli_stmt_close($stmt);}/* 接続を閉じます */mysqli_close($link);?>
上の例の出力は以下となります。
Error: 42S02.