ホームページ >データベース >mysql チュートリアル >MySQL AUTO_INCREMENT 値が InnoDB トランザクションでロールバックしないのはなぜですか?

MySQL AUTO_INCREMENT 値が InnoDB トランザクションでロールバックしないのはなぜですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-15 07:14:10407ブラウズ

Why Don't MySQL AUTO_INCREMENT Values Roll Back in InnoDB Transactions?

MySQL AUTO_INCREMENT: ロールバックの謎を解明する

MySQL では、InnoDB トランザクションで AUTO_INCREMENT フィールドを利用すると特有の動作が発生します: ロールバックは影響しませんAUTO_INCREMENT 値。この設計選択の背後にある理由を理解することが重要です。

次のシナリオを考えてみましょう:

シナリオ:

  1. プログラム 1 がトランザクションを開始し、レコードをテーブル FOO に挿入し、AUTO_INCREMENT 値を割り当てます。 557.
  2. プログラム 2 もトランザクションを開始し、FOO にレコードを挿入し、取得します。 558.
  3. プログラム 2 は、FOO の 558 値を参照して、テーブル BAR にレコードを挿入します。
  4. プログラム 2 はトランザクションをコミットします。
  5. プログラム 3 はレポートを生成しますテーブル FOO に基づいており、値 558 のレコードが含まれます。
  6. プログラム 1 は最終的にトランザクションをロールバックします。

ロールバックと AUTO_INCREMENT:

データベース システムは通常、AUTO_INCREMENT 値をロールバックしません。影響:

  • データ整合性: ロールバック時に 557 値が減分された場合、557 より大きいキーを持つ他のレコードの値は無効になります。
  • 外部キー制約: テーブル BAR 内の 558 への参照は次のようになります。 FOO の 558 レコードが削除された場合、孤立します。
  • レポートの不一致: プログラム 3 によって生成されたレポートは、値 557 のロールバックされたレコードを除外するように修正する必要があります。

回避策と代替案:

AUTO_INCREMENT フィールドはロールバックできませんが、特定の要件に対処する代替ソリューションがあります:

  • 不完全なレコード: 監査目的、レコードのステータス フラグを維持することを検討してください。作成時に「不完全」とマークされたレコードは、AUTO_INCREMENT 値に影響を与えることなくロールバックでき、監査証跡が得られます。

これらの回避策を実装するには、データの整合性、パフォーマンス、および特定のビジネス ニーズを慎重に考慮する必要があります。

以上がMySQL AUTO_INCREMENT 値が InnoDB トランザクションでロールバックしないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。