ホームページ > バックエンド開発 > PHPチュートリアル > MySQLi クエリが時々サイレントに失敗し、明示的な False 戻り値のチェックが必要になるのはなぜですか?

MySQLi クエリが時々サイレントに失敗し、明示的な False 戻り値のチェックが必要になるのはなぜですか?

Patricia Arquette
リリース: 2024-12-30 10:19:09
オリジナル
159 人が閲覧しました

Why Do MySQLi Queries Sometimes Fail Silently, Requiring Explicit False Return Value Checks?

MySQLi クエリ エラーを例外として処理する

はじめに

MySQLi では、クエリ エラーは通常、警告またはエラー メッセージとして報告されます。ただし、開発者は、エラー処理を改善するために、これらのエラーを例外に変換することを好む場合があります。この記事では、MySQLi クエリ エラーを例外に変えるプロセスを検証し、クエリの失敗が警告や例外をトリガーせずに false を返すという一般的な問題に対処します。

問題

MySQLi の実行時クエリの場合、開発者はクエリ エラーを検出するために mysqli_query() が false を返したかどうかをよく確認します。ただし、このアプローチは不便な場合があり、予期しないエラーが常に検出されるとは限りません。

以前のコード

$result = mysqli_query($DBlink, $SQL);
if ($result === false) {
    throw new MySQLiQueryException($SQL, mysqli_error($DBlink), mysqli_errno($DBlink));
}
ログイン後にコピー

質問

場合によっては、クエリが失敗したときに警告も例外もスローされず、開発者が明示的にチェックする必要があるのはなぜですかmysqli_query() からの false 戻り値の場合?

Answer

MySQLi クエリ エラーの例外を有効にするには、mysqli_report() 関数を使用してエラー レポート レベルを正しく設定する必要があります。 。次のコード スニペットは、適切な使用法を示しています。

mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);
ログイン後にコピー

エラー報告レベルを MYSQLI_REPORT_ERROR | に設定することによって。 MYSQLI_REPORT_STRICT を使用すると、MySQLi はクエリの失敗を含むすべてのエラーと厳密なエラーに対して例外のスローを開始します。

注意

エラー処理には例外を使用することが一般的に推奨されますが、重要です。 try-catch ブロックの過度の使用を避けるため。コードの肥大化を最小限に抑え、一貫したエラー報告を保証するために、エラー処理は共通のエラー ハンドラーを通じて一元化される必要があります。

以上がMySQLi クエリが時々サイレントに失敗し、明示的な False 戻り値のチェックが必要になるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート