PHP での MySQL API の混合
MySQL PHP API は、MySQL データベースと対話するための 2 つのインターフェイス、mysql_ と mysqli_ を提供します。これらの API を混合すると便利に見えるかもしれませんが、この方法は絶対にお勧めできません。
API を混合することはできません
基本的に、mysql_ と mysqli_ は異なるアーキテクチャを持つ別個の API であり、互換性がありません。リソースの種類。そのため、一方の API の関数を、他方の API で作成されたリソースで使用することはできません。
エラー例
提供されているコード例は、2 つの API を混合しようとしたときの問題を示しています。 API:
$con=mysql_connect("localhost", "root" ,"" ,"mysql"); if( mysqli_connect_errno( $con ) ) { echo "failed to connect"; }else{ echo "connected"; } mysqli_close($con); // Error: Incompatible resource type
このコードは、によって作成されたリソースに対して mysqli_connect_errno() を使用しようとします。 mysql_connect() により、不一致が発生します。
接続の有効性の確認
接続が有効かどうかを確認するには、対応する API のエラー報告関数を使用します:
結論
それは不可欠ですさまざまな MySQL インターフェイスを操作するときに API 境界を遵守するため。互換性のない関数やリソースを使用すると、エラーや予期しない動作が発生する可能性があります。
以上がPHP で「mysql_」 API と「mysqli_」 API を混在させないほうがよいのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。