PHP Conference Japan 2024

mysqli::$sqlstate

mysqli_sqlstate

(PHP 5, PHP 7, PHP 8)

mysqli::$sqlstate -- mysqli_sqlstate返回上一个 MySQL 操作的 SQLSTATE 错误

描述

面向对象风格

过程化风格

mysqli_sqlstate(mysqli $mysql): string

返回一个包含上一个错误的 SQLSTATE 错误代码的字符串。错误代码由五个字符组成。'00000' 表示没有错误。这些值由 ANSI SQL 和 ODBC 指定。有关可能值的列表,请参阅 » https://dev.mysqlserver.cn/doc/mysql/en/error-handling.html

注意:

请注意,并非所有 MySQL 错误都已映射到 SQLSTATE。对于未映射的错误,使用值 HY000(一般错误)。

参数

mysql

仅过程化风格:由 mysqli_connect()mysqli_init() 返回的 mysqli 对象

返回值

返回一个包含上一个错误的 SQLSTATE 错误代码的字符串。错误代码由五个字符组成。'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.

参见

添加注释

用户贡献的注释

此页面没有用户贡献的注释。
To Top