中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql跨庫事務XA操作示例

發布時間:2020-09-01 18:53:48 來源:腳本之家 閱讀:174 作者:雨落知音 欄目:MySQL數據庫

本文實例講述了mysql跨庫事務XA操作。分享給大家供大家參考,具體如下:

前一段時間在工作中遇到了跨庫事務問題,后來在網上查詢了一下,現在做一下整理和總結。

1、首先要確保mysql開啟XA事務支持

SHOW VARIABLES LIKE '%XA%'

mysql跨庫事務XA操作示例

如果innodb_support_xa的值是ON就說明mysql已經開啟對XA事務的支持了。

如果不是就執行:

SET innodb_support_xa = ON

<?PHP
$dbtest1 = new mysqli("172.20.101.17","public","public","dbtest1")or die("dbtest1 連接失敗");
$dbtest2   = new mysqli("172.20.101.18","public","public","dbtest2")or die("dbtest2 連接失敗");
//為XA事務指定一個id,xid 必須是一個唯一值。
$xid = uniqid("");
//兩個庫指定同一個事務id,表明這兩個庫的操作處于同一事務中
$dbtest1->query("XA START '$xid'");//準備事務1
$dbtest2->query("XA START '$xid'");//準備事務2
try {
  //$dbtest1
  $return = $dbtest1->query("UPDATE member SET name='唐大麥' WHERE id=1") ;
  if($return == false) {
    throw new Exception("庫dbtest1@172.20.101.17執行update member操作失敗!");
  }
  //$dbtest2
  $return = $dbtest2->query("UPDATE memberpoints SET point=point+10 WHERE memberid=1") ;
  if($return == false) {
    throw new Exception("庫dbtest1@172.20.101.18執行update memberpoints操作失敗!");
  }
  //階段1:$dbtest1提交準備就緒
  $dbtest1->query("XA END '$xid'");
  $dbtest1->query("XA PREPARE '$xid'");
  //階段1:$dbtest2提交準備就緒
  $dbtest2->query("XA END '$xid'");
  $dbtest2->query("XA PREPARE '$xid'");
  //階段2:提交兩個庫
  $dbtest1->query("XA COMMIT '$xid'");
  $dbtest2->query("XA COMMIT '$xid'");
}
catch (Exception $e) {
  //階段2:回滾
  $dbtest1->query("XA ROLLBACK '$xid'");
  $dbtest2->query("XA ROLLBACK '$xid'");
  die($e->getMessage());
}
$dbtest1->close();
$dbtest2->close();
?>

XA的性能很低。一個數據庫的事務和多個數據庫間的XA事務性能對比可發現,性能差10倍左右

更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL事務操作技巧匯總》、《MySQL查詢技巧大全》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》

希望本文所述對大家MySQL數據庫計有所幫助。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

开江县| 收藏| 怀化市| 郯城县| 揭西县| 玉林市| 铜川市| 绥阳县| 恩施市| 枞阳县| 乡宁县| 信阳市| 康乐县| 城市| 寻乌县| 平罗县| 桐乡市| 武陟县| 陆良县| 高邑县| 绍兴市| 开封县| 诏安县| 正阳县| 阜阳市| 光泽县| 阳城县| 双鸭山市| 容城县| 万山特区| 清镇市| 东方市| 建阳市| 华亭县| 汝城县| 富锦市| 普格县| 巩义市| 射洪县| 丽水市| 芒康县|