欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

mysql跨庫事務(wù)XA操作示例

 更新時間:2019年04月29日 10:49:26   作者:雨落知音  
這篇文章主要介紹了mysql跨庫事務(wù)XA操作,結(jié)合實例形式分析了php+mysql實現(xiàn)跨庫事務(wù)XA操作具體操作步驟與相關(guān)注意事項,需要的朋友可以參考下

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

前一段時間在工作中遇到了跨庫事務(wù)問題,后來在網(wǎng)上查詢了一下,現(xiàn)在做一下整理和總結(jié)。

1、首先要確保mysql開啟XA事務(wù)支持

SHOW VARIABLES LIKE '%XA%'

如果innodb_support_xa的值是ON就說明mysql已經(jīng)開啟對XA事務(wù)的支持了。

如果不是就執(zhí)行:

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事務(wù)指定一個id,xid 必須是一個唯一值。
$xid = uniqid("");
//兩個庫指定同一個事務(wù)id,表明這兩個庫的操作處于同一事務(wù)中
$dbtest1->query("XA START '$xid'");//準備事務(wù)1
$dbtest2->query("XA START '$xid'");//準備事務(wù)2
try {
  //$dbtest1
  $return = $dbtest1->query("UPDATE member SET name='唐大麥' WHERE id=1") ;
  if($return == false) {
    throw new Exception("庫dbtest1@172.20.101.17執(zhí)行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執(zhí)行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的性能很低。一個數(shù)據(jù)庫的事務(wù)和多個數(shù)據(jù)庫間的XA事務(wù)性能對比可發(fā)現(xiàn),性能差10倍左右

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

希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。

相關(guān)文章

最新評論