(PHP 5, PHP 7, PHP 8)
mysqli::$sqlstate -- mysqli_sqlstate — 直前の MySQL の操作での SQLSTATE エラーを返す
オブジェクト指向型
手続き型
   直近のエラーについて、SQLSTATE エラーコードを含む文字列を返します。
   エラーコードは 5 つの文字で構成されています。'00000'
   はエラーが発生しなかったことを意味します。この値は、ANSI SQL および
   ODBC で定義されています。とりうる値の一覧は
   » http://dev.mysql.com/doc/mysql/en/error-handling.html
   を参照ください。
  
注意:
すべての MySQL エラーが SQLSTATE に対応しているわけではないことに 注意してください。そのようなエラーが発生した場合は、
HY000(一般的なエラー)が返されます。
   直前のエラーに関する SQLSTATE エラーコードを含む文字列を返します。
   エラーコードは 5 文字で構成され、'00000'
   はエラーが発生しなかったことを意味します。
  
例1 $mysqli->sqlstate の例
オブジェクト指向型
<?php
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$mysqli = new mysqli("localhost", "my_user", "my_password", "world");
/* City テーブルはすでに存在します。そのためエラーとなります */
try {
    $mysqli->query("CREATE TABLE City (ID INT, Name VARCHAR(30))");
} catch (mysqli_sql_exception) {
    printf("Error - SQLSTATE %s.\n", $mysqli->sqlstate);
}手続き型
<?php
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
$link = mysqli_connect("localhost", "my_user", "my_password", "world");
/* City テーブルはすでに存在します。そのためエラーとなります */
try {
    mysqli_query($link, "CREATE TABLE City (ID INT, Name VARCHAR(30))");
} catch (mysqli_sql_exception) {
    printf("Error - SQLSTATE %s.\n", mysqli_sqlstate($link));
}上の例の出力は以下となります。
Error - SQLSTATE 42S01.
