カテゴリー:
PDO
閲覧数:437 配信日:2016-03-29 12:08
トランザクションを使用する場合
PDO::beginTransaction() メソッドを使用して トランザクションを初期化
・使用しているドライバが トランザクションをサポートしていない場合は PDOException が スローされる
※深刻な状態であるため、エラー処理の設定に かかわらず常にスローされる
初期化した後でトランザクションを 終了させるためには?
トランザクション内でのコードが成功
→ PDO::commit()
トランザクション内でのコードが失敗
→ PDO::rollBack()
スクリプトが予期せぬ状態で終了した場合
データ不整合発生を避けるための安全装置が作動
・明示的にコミットしていない
・恐らく何かおかしなことが 起こったのだろうと推測
→ データを守るため ロールバックが実行される
注意
・自動的にロールバックが行われるのは、トランザクションを PDO::beginTransaction() で開始した場合のみ
・トランザクションを開始クエリを手動で発行した場合、 PDO はそれを知ることができない
・そのため、何か問題が発生しても ロールバックすることはできない