MySQL はセーブポイントを使用してネストされたトランザクションをどのように処理しますか?

Patricia Arquette
リリース: 2024-11-28 03:50:22
オリジナル
574 人が閲覧しました

How Does MySQL Handle Nested Transactions Using Savepoints?

MySQL のネストされたトランザクション

他の特定のデータベース管理システムとは異なり、MySQL はネストされたトランザクションをネイティブにサポートしません。これは、既存のトランザクション内に新しいトランザクションを作成できないことを意味します。ただし、MySQL で使用される一般的なストレージ エンジンである MySQL InnoDB は、セーブポイントを使用してネストされたトランザクションのような動作を管理するソリューションを提供します。

InnoDB の SAVEPOINTS

セーブポイントを使用すると、トランザクション内に一時的なマイルストーンを作成できます。セーブポイントを作成して名前を付け、そのセーブポイントにロールバックして、その後に行われた操作を元に戻すことができます。これにより、ネストされたトランザクションと同様のレベルの細分性と柔軟性が提供されます。

SAVEPOINTS の使用方法

MySQL でセーブポイントを使用するには、次の手順に従います。

  1. START TRANSACTION を使用してトランザクションを開始しますコマンド。
  2. SAVEPOINT コマンドを使用してセーブポイントを作成します。 tran2 などの意味のある名前を付けます。
  3. セーブポイント内に含める操作を実行します。
  4. セーブポイントにロールバックするには、ROLLBACK TO コマンドの後にセーブポイント名を指定します。
  5. トランザクション全体をロールバックしたい場合は、ROLLBACK を使用します。 command.

次の例を考えてみましょう:

CREATE TABLE t_test (id INT NOT NULL PRIMARY KEY) ENGINE=InnoDB;

START TRANSACTION;

INSERT
INTO    t_test
VALUES  (1);

SELECT  *
FROM    t_test;

 id
---
  1

SAVEPOINT tran2;

INSERT
INTO    t_test
VALUES  (2);

SELECT  *
FROM    t_test;

 id
---
  1
  2

ROLLBACK TO tran2;

SELECT  *
FROM    t_test;

 id
---
  1

ROLLBACK;

SELECT  *
FROM    t_test;

 id
---
ログイン後にコピー

この例では、セーブポイントにロールバックする方法を示します。 (tran2) し、トランザクション全体をロールバックします。

以上がMySQL はセーブポイントを使用してネストされたトランザクションをどのように処理しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート