トランザクションおよび自動コミット

データベース関連PDO

トランザクションとは?

 状態:-  閲覧数:1,741  投稿日:2016-03-22  更新日:2016-03-27  
4 つの機能(ACID) を提供するもの
1.原子性 - Atomicity
2.一貫性 - Consistency
3.独立性 - Isolation
4.永続性 - Durability

トランザクション内で実行された作業
・例え段階的に行われたものであったとしてもデータベースに安全に反映される ことが保証されている
・まだコミットされていなければ、いつでも自動的に取り消すことが できる

トランザクションの一般的な実装
・変更内容を一時的に「蓄えて」おき、 それを一気に適用する

導入メリット
・更新処理の 性能を劇的に向上させる
・より高速になり、 また、より堅牢になる



PDO で最初に接続オープンした際には、「自動コミット」モードで動作

 閲覧数:566 投稿日:2016-03-27 更新日:2016-03-29 

自動コミットモードとは?


データベースがトランザクションをサポートしていたら個々のクエリが 暗黙的なトランザクションのもとで実行され、サポートしていなかったら トランザクションを使用せずに実行される





トランザクションを使用する場合

 閲覧数:494 投稿日:2016-03-29 更新日:2016-04-05 

トランザクションを使用する場合


PDO::beginTransaction() メソッドを使用して トランザクションを初期化
・使用しているドライバが トランザクションをサポートしていない場合は PDOException が スローされる
※深刻な状態であるため、エラー処理の設定に かかわらず常にスローされる


初期化した後でトランザクションを 終了させるためには?


トランザクション内でのコードが成功
→ PDO::commit()

トランザクション内でのコードが失敗
→ PDO::rollBack()


スクリプトが予期せぬ状態で終了した場合


データ不整合発生を避けるための安全装置が作動
・明示的にコミットしていない
・恐らく何かおかしなことが 起こったのだろうと推測
→ データを守るため ロールバックが実行される

注意
・自動的にロールバックが行われるのは、トランザクションを PDO::beginTransaction() で開始した場合のみ
・トランザクションを開始クエリを手動で発行した場合、 PDO はそれを知ることができない
・そのため、何か問題が発生しても ロールバックすることはできない




PDO

コメント投稿(ログインが必要)



週間人気ページランキング / 6-25 → 7-1
順位 ページタイトル抜粋 アクセス数
1 PHPで定数を定義する方法は2種類ある / 配列定数の定義 7
2 エラー | エラーメッセージ 5
3 ブラウザを閉じたらセッションデータはどうなるの? | セッション 4
3 PHPにおけるメソッドのオーバーライドについて /「引数の数や型は、親クラスのメソッドと完全に一致していなければなりません。」とは具体的にどういう意味ですか? 4
3 オブジェクト関係マッピング | データベース関連 4
4 「POSIX正規表現」と「PCRE正規表現」の違い 3
4 Fatal error: Uncaught Error: Call to a member function modify() on string | Fatal error(エラーメッセージ) 3
4 register_shutdown_function | 関数処理 関数 3
4 Notice(エラーメッセージ) カテゴリー 3
4 _FILE__ | 定数 3
4 PHP用語 3
5 Fatal error(エラーメッセージ) カテゴリー 2
5 session_start() | セッション 2
5 You currently have Essential access which includes access to Twitter API v2 endpoints only. If you need access to this endpoint, you’ll need to apply for Elevated access via the Developer Portal. | Twitter API(エラーメッセージ) 2
5 Fatal error: Access level to ▲::$△ must be protected (as in class ●) or weaker | Fatal error(エラーメッセージ) 2
5 Warning: PDO::query(): LOAD DATA LOCAL INFILE forbidden | Warning(エラーメッセージ) 2
5 Mailer Error: SMTP connect() failed. https://github.com/PHPMailer/PHPMailer/wiki/Troubleshooting | エラーメッセージ 2
5 Propel | データベース関連 2
5 syntax error | エラーメッセージ 2
5 ブラウザを閉じたらセッションデータはどうなるの? | セッション 2
2025/7/2 1:01 更新