MySQL クロスデータベーストランザクション XA 操作の例

MySQL クロスデータベーストランザクション XA 操作の例

この記事では、例を使用して、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データベース設計に役立つことを願っています。

以下もご興味があるかもしれません:
  • MySQL に絵文字を保存するときに表示されるエラー メッセージ「java.sql.SQLException: 文字列値が正しくありません:'\xF0\x9F\x92\xA9\x0D\x0A...'」の解決方法
  • Xampp サーバーで MySQL パスワードを変更する方法 (画像付き)
  • Mac で XAMPP に付属する MySQL をターミナルを使って開く方法
  • xampp で MySQL のデフォルト パスワードを変更する方法
  • ThinkPHP フレームワークの構築とよくある問題 (XAMPP インストール失敗、Apache/MySQL 起動失敗)
  • xampp で MySQL のデフォルトの空のパスワード (ルート パスワード) を変更する方法
  • MySQLのXAトランザクションリカバリプロセスの詳細な説明
  • xampp のセルフスタートと mysql.sock の問題を解決する
  • MySQL データベースは XA 仕様をどのように実装しますか?

<<:  メッセージボードにメッセージを追加および削除するための JavaScript

>>:  Apache Flink の任意の Jar パッケージのアップロードにより、リモート コード実行の脆弱性が再発する問題が発生する (脆弱性警告)

推薦する

HTMLメタの大きな役割

メタ属性には、name と http-equiv の 2 つがあります。 name 属性は主に、We...

JavaScriptで計算機機能を実現するプロセスの詳細な説明

目次1. 電卓機能の紹介2. 計算機ページのデザイン1. ナビゲーションバー2. データ部分3. i...

Webフロントエンドインターフェースの設計に必須のスキル

[必須] ユーザーインターフェースPhotoShop/花火デザインアーティストと協力して、スケッチを...

MySQL データベースのインデックスとトランザクション

目次1. 索引1.1 コンセプト1.2 機能1.3 索引作成の原則1.3.1 ディスクアクセス回数を...

CSS カウンターとコンテンツの概要

コンテンツ プロパティは CSS 2.1 で導入され、:before および :after 疑似要素...

MySQL FAQ シリーズ: ibdata1 ファイルのサイズが突然増加しないようにする方法

0. はじめにibdata1 ファイルとは何ですか? ibdata1 は、innodb システム テ...

ウェブサイトのコンテンツが検索エンジンに含まれないようにする方法

通常、Web サイトを構築する目的は、検索エンジンにインデックス登録してもらい、プロモーションを拡大...

学生情報管理システムを実装するためのJavaScript+HTML

目次1. はじめに2. レンダリング3. コード4. 学生情報管理システムのメインインターフェース1...

Linux における SUID、SGID、SBIT の素晴らしい使い方の詳細な説明

序文Linux のファイル権限管理はとにかく素晴らしいです。SUID、SGID、SBIT の機能を確...

HTML テーブル マークアップ チュートリアル (28): セルの境界線の色属性 BORDERCOLOR

テーブルを美しくするために、セルごとに異なる境界線の色を設定できます。基本的な構文<TD 境界...

MySQL 最適化のヒント: 重複削除の実装方法の分析 [数百万のデータ]

この記事では、MySQL 最適化のヒントで重複したエントリを削除する方法を例を使って説明します。ご参...

Raspberry Pi 3B+ に 64 ビット Ubuntu システムと Docker ツールをインストールする詳細な手順

Raspberry Pi 3B に 64 ビット アプリケーション (64 ビット JDK など) ...

大規模なMySQLデータベース用のマスタースレーブシステムを構築するアイデアを共有する

今週は戦争のように忙しかったです。他人に操られているような気がします。毎日朝早く出勤して夜遅く帰り、...

組み込みオブジェクトに関するJavascriptの基礎

目次1. 組み込みオブジェクトの紹介1.1 数学オブジェクト1.2 数学における方法1.3 日付オブ...