この記事では、例を使用して、MySQL のデータベース間トランザクション XA 操作について説明します。ご参考までに、詳細は以下の通りです。 以前、仕事でデータベース間トランザクションの問題に遭遇しました。その後、インターネットで検索し、整理して要約します。 1. まず、MySQLがXAトランザクションサポートを有効にしていることを確認します。 '%XA%' のような変数を表示 innodb_support_xa の値が ON の場合、MySQL で XA トランザクションのサポートが有効になっていることを意味します。 そうでない場合は、次を実行します。 innodb_support_xa を ON に設定する <?PHP $dbtest1 = new mysqli("172.20.101.17","public","public","dbtest1")またはdie("dbtest1接続に失敗しました"); $dbtest2 = new mysqli("172.20.101.18","public","public","dbtest2")またはdie("dbtest2接続に失敗しました"); //XA トランザクションの ID を指定します。xid は一意の値である必要があります。 $xid = uniqid(""); // 2 つのデータベースは同じトランザクション ID を指定しており、2 つのデータベースの操作が同じトランザクション内にあることを示しています $dbtest1->query("XA START '$xid'"); // トランザクション 1 を準備します $dbtest2->query("XA START '$xid'"); //トランザクション2を準備する 試す { //$dbtest1 $return = $dbtest1->query("UPDATE member SET name='唐大麦' WHERE id=1"); 戻り値が偽の場合 throw new Exception("ライブラリ [email protected] でメンバー更新操作が失敗しました!"); } //$dbtest2 $return = $dbtest2->query("UPDATE memberpoints SET point=point+10 WHERE memberid=1"); 戻り値が偽の場合 throw new Exception("データベース [email protected] でメンバーポイントの更新操作が失敗しました!"); } //フェーズ 1: $dbtest1 は送信する準備ができています $dbtest1->query("XA END '$xid'"); $dbtest1->クエリ("XA PREPARE '$xid'"); //フェーズ 1: $dbtest2 は送信する準備ができています $dbtest2->query("XA END '$xid'"); $dbtest2->query("XA PREPARE '$xid'"); //フェーズ 2: 2 つのデータベースを送信します $dbtest1->query("XA COMMIT '$xid'"); $dbtest2->query("XA COMMIT '$xid'"); } キャッチ(例外$e){ //フェーズ 2: ロールバック $dbtest1->query("XA ROLLBACK '$xid'"); $dbtest2->query("XA ROLLBACK '$xid'"); die($e->getMessage()); } $dbtest1->閉じる(); $dbtest2->close(); ?> XA のパフォーマンスは非常に低いです。 1 つのデータベース内のトランザクションのパフォーマンスと複数のデータベース間の XA トランザクションのパフォーマンスを比較すると、パフォーマンスが約 10 倍低下していることがわかります。 MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL トランザクション操作スキルの概要」、「MySQL クエリ スキル集」、「MySQL ストアド プロシージャ スキル集」、「MySQL データベース ロック関連スキルの概要」、および「MySQL 共通関数の概要」 この記事が皆様のMySQLデータベース設計に役立つことを願っています。 以下もご興味があるかもしれません:
|
<<: メッセージボードにメッセージを追加および削除するための JavaScript
>>: Apache Flink の任意の Jar パッケージのアップロードにより、リモート コード実行の脆弱性が再発する問題が発生する (脆弱性警告)
1. 互換性以下のように表示されます。 互換性は問題ありません。IE を除き、他のブラウザは基本的に...
目次序文APPメソッドにジャンプURLスキームメタタグユニバーサルリンクさまざまな使い方URLスキー...
【1】存在するループを使用して外部テーブルを 1 つずつクエリし、各クエリの存在する条件ステートメン...
WeChatアプレットの簡単な計算機は参考用です。具体的な内容は次のとおりです。 1. はじめに1....
CentOS7 システムを使用するのは今回が初めてで、ネットワーク構成を行う際に多くの問題が発生し...
ストアド関数ストアド関数とは: SQL コードの一部をカプセル化し、特定の関数を完了して、結果を返し...
この記事の冒頭で、以前書いた入門記事の間違いを訂正したいと思います。初心者を再び誤解させないように、...
目次CSS3 ボックスモデルa. CSS3 フィルターb. CSS3 calc関数c. CSS3 ト...
目次序文Dockerfile の紹介Dockerfileはイメージプロセスを構築するDockerfi...
目次fileReader に関する落とし穴iOS における FileReader の落とし穴 (イメ...
[概要] この記事では、自作の Docker プラットフォームをベースに完全な ELK システムを素...
HTML の img タグで画像の中心を表示する方法は、現在 3 つあります。ここで記録しておきま...
場合によっては、SQL ステートメントが通常どおり、非常に速く実行される状況に遭遇することがあります...
1. はじめに行ロックとテーブルロックの違いは面接で頻繁に出てくるはずです。MySQL のロックにつ...
Win10 システムに MySQL 8.0 をインストールする際に発生する問題と解決策は次のとおりで...