ホームページ >バックエンド開発 >PHPチュートリアル >PHP PDO関数ライブラリ詳細解説、PDO関数ライブラリ詳細解説_PHPチュートリアル
PDO は、さまざまなデータベースのアクセス インターフェイスを統合する「データベース アクセス抽象化レイヤー」です。mysql や mysqli の関数ライブラリと比較して、PDO は ADODB や MDB2 と比較して、より効率的にクロスデータベースを使用できます。 。現時点では、「データベース抽象化レイヤー」の実装には長い道のりがあります。PDO などの「データベース アクセス抽象化レイヤー」を使用するのが良い選択です。
PDO には 3 つの事前定義クラスが含まれています
PDO には、PDO、PDOStatement、PDOException という 3 つの事前定義クラスが含まれています。
1.PDO
PDO->beginTransaction() — ロールバックの開始点をマークします
PDO->commit() — ロールバックの終了点をマークし、SQL を実行します
PDO->rollBack() — ロールバックを実行します
PDO->__construct () — PDO リンク データベースのインスタンスを作成します
PDO->errorCode() — エラー コードを取得します
PDO->errorInfo() — エラー情報を取得します
PDO->exec() — SQL ステートメントを処理し、影響を受けるエントリの数
PDO->getAttribute() — 「データベース接続オブジェクト」の属性を取得します
PDO->getAvailableDrivers() — 有効な PDO ドライバー名を取得します
PDO->lastInsertId() — 書き込みを取得します入力された最後のデータの主キー値
PDO->prepare() — 「クエリ オブジェクト」を生成します
PDO->query() — SQL ステートメントを処理し、「PDOStatement」を返します
PDO->quote () — SQL の文字列に引用符を追加します
PDO->setAttribute() — 「データベース接続オブジェクト」の属性を設定します
詳しい説明 1) PDOでのデータベース接続
$dsn = 'mysql:dbname=ent;host=127.0.0.1';
$user = 'root';
$password = '123456';
try {
$dbh = new PDO($dsn, $user, $password, array(PDO::ATTR_PERSISTENT => true));
$dbh->query('set names utf8;');
foreach ($dbh->query) ('SELECT * from tpm_juese') as $row) {
print_r($row);
}
} catch (PDOException $e) {
echo '接続に失敗しました: ' $e->getMessage();
}
多くの Web アプリケーションは、データベースへの永続的な接続を使用して最適化されます。永続接続はスクリプトの終了時に閉じられず、別のスクリプトが同じ ID で接続を要求したときにキャッシュされ、再利用されます。
永続的な接続のキャッシュにより、スクリプトがデータベースと通信する必要があるたびに新しい接続をデプロイするリソースの消費を回避できるため、Web アプリケーションが高速になります。
上記の例の配列 (PDO::ATTR_PERSISTENT => true) は、接続タイプを永続接続に設定します。
PDO->beginTransaction()、PDO->commit()、PDO->rollBack()は、ロールバック機能をサポートしている場合に併用されます。 PDO->beginTransaction() メソッドは開始点をマークし、PDO->commit() メソッドはロールバックの終了点をマークして SQL を実行し、PDO->rollBack() はロールバックを実行します。
try {
$dbh = new PDO('mysql:host=localhost;dbname=test', 'root', ”);
$dbh->query('set names utf8;');
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dbh->exec(”INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('mick', 22);”);
$dbh->exec("INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('lily', 29);");
$dbh->exec("INSERT INTO ` test`.`table` (`name` ,`age`)VALUES ('susan', 21);”);
$dbh->commit();
$dbh->rollBack();
echo "Failed: " . $e->getMessage();
}
?>
これで、PDO を介した接続が確立されました。 、クエリを展開する前に、PDO がトランザクションをどのように管理するかを理解する必要があります。これまでトランザクションに遭遇したことがない場合は、(ここで簡単に説明します:) トランザクションには 4 つの主要なプロパティがあります: 原子性、一貫性、分離性、耐久性 (ACID) 平易な言葉で言うと、トランザクション内のすべての作業が送信された場合、段階的に実行される場合でも、安全にデータベースに適用され、他の接続によって干渉されないようにする必要があります。リクエストでエラーが発生した場合、トランザクション作業を簡単かつ自動的にキャンセルすることもできます。
残念ながら、すべてのデータベースがトランザクションをサポートしているわけではないため、接続の確立時に PDO を「自動コミット」モードとみなされるモードで実行する必要があります。オートコミット モードは、データベースがトランザクションをサポートしているか、データベースがトランザクションをサポートしていないためにトランザクションがないかに関係なく、実行するすべてのクエリに独自の暗黙的なトランザクション処理があることを意味します。トランザクションが必要な場合は、PDO->beginTransaction() メソッドを使用してトランザクションを作成する必要があります。基礎となるドライバーがトランザクションをサポートしていない場合、PDOException がスローされます (例外処理の設定に関係なく、これは常に重大なエラー状態であるため)。トランザクション内では、トランザクション内のコードが正常に実行されたかどうかに応じて、PDO->commit() または PDO->rollBack() を使用してトランザクションを終了できます。
スクリプトが終了するか接続が閉じられるとき、未完了のトランザクションがまだある場合、PDO はそれを自動的にロールバックします。これは、スクリプトが予期せず終了した場合の安全な解決策です。トランザクションを明示的にコミットしない場合、スクリプトは何か問題が発生したものとみなし、データの安全性を確保するためにロールバックを実行します。
2.PDOステートメント
PDOStatement->bindColumn() — 列を PHP 変数にバインドします
PDOStatement->bindParam() — パラメータを指定された変数名にバインドします
PDOStatement->bindValue() — 値をパラメータにバインドします
PDOStatement ->closeCursor() — カーソルを閉じて、ステートメントを再度実行できるようにします。
PDOStatement->columnCount() — 結果セット内の列の数を返します。
PDOStatement->errorCode() — 関連する SQLSTATE を取得します。ステートメントハンドルの最後の操作を使用して
PDOStatement->errorInfo() — ステートメントハンドルの最後の操作に関連付けられた拡張エラー情報を取得します
PDOStatement->execute() — 準備されたステートメントを実行します
PDOStatement->fetch( ) — 結果セットから次の行をフェッチします
PDOStatement->fetchAll() — 結果セットのすべての行を含む配列を返します
PDOStatement->fetchColumn() — 結果セットの次の行から単一の列を返します
PDOStatement->fetchObject() — 次の行をフェッチし、オブジェクトとして返します。
PDOStatement->getAttribute() — ステートメント属性を取得します。
PDOStatement->getColumnMeta() — 結果セット内の列のメタデータを返します。
PDOStatement->nextRowset() — 複数行セット ステートメント ハンドル内の次の行セットに進みます
PDOStatement->rowCount() — 最後の SQL ステートメントの影響を受ける行数を返します
PDOStatement->setAttribute() —ステートメント属性を設定します
PDOStatement->setFetchMode() — このステートメントのデフォルトのフェッチ モードを設定します
3.PDO例外
PDO は 3 つの異なるエラー処理戦略を提供します。
1. PDO::ERRMODE_SILENT
これがデフォルトのモードです。 PDO は、ステートメント オブジェクトとデータベース オブジェクトに単純なエラー コードを設定します。エラーがステートメント オブジェクトの呼び出しによって引き起こされたかどうかを確認するには、PDO->errorCode() メソッドと PDO->errorInfo() メソッドを使用できます。 , そのオブジェクトに対して PDOStatement->errorCode() メソッドまたは PDOStatement->errorInfo() メソッドを使用して、エラー情報を取得できます。データベース オブジェクトの呼び出し時にエラーが発生した場合は、データベース オブジェクトでこれら 2 つのメソッドを呼び出す必要があります。
2. PDO::ERRMODE_WARNING
エラー コードの設定に加えて、PDO は従来の E_WARNING メッセージを発行します。この設定は、デバッグ時や、プログラムの流れを中断せずに何が問題になったのかだけを確認したい場合に便利です。
3. PDO::ERRMODE_EXCEPTION
エラー コードを設定するための添付ファイルとして、PDO は PDOException をスローし、エラー コードとエラー情報を反映するようにそのプロパティを設定します。この設定は、スクリプト内のエラー ポイントを効果的に「爆発」させ、コード内のエラーの可能性のある領域を迅速に示すため、デバッグ時にも非常に役立ちます。 (例外によってスクリプトが中止された場合、トランザクションは自動的にロールバックされることに注意してください。)
例外モードは、従来の PHP スタイルのエラー処理構造を使用する前よりも明確な構造を使用してエラーを処理できるため、非常に便利です。使用するコードが少なくなります。 Quiet モードを使用するよりもネスティングが可能で、各データベース アクセスの戻り値をより明示的に確認できます。
PHP の例外の詳細については、「例外」の章を参照してください。
PDO は SQL-92 SQLSTATE に基づいたエラー コード文字列を使用します。特定の PDO ドライバーは、独自のコードを適切な SQLSTATE コードにマップする必要があります。 PDO->errorCode() メソッドは、単一の SQLSTATE コードのみを返します。エラーに関するより具体的な情報が必要な場合、PDO には PDO->errorInfo() メソッドも用意されており、SQLSTATE コード、特定のデータベース ドライバーのエラー コード、および特定のデータベースのエラーの説明を含むメッセージを返すことができます。ドライバー。
属性リスト:
PDO::PARAM_BOOL