主頁(yè) > 知識(shí)庫(kù) > mysql跨庫(kù)事務(wù)XA操作示例

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

熱門(mén)標(biāo)簽:百度地圖標(biāo)注要什么軟件 400電話(huà)申請(qǐng)廠家現(xiàn)貨 徐涇鎮(zhèn)騰訊地圖標(biāo)注 昌德訊外呼系統(tǒng) 中國(guó)地圖標(biāo)注公司 天津公司外呼系統(tǒng)軟件 電話(huà)機(jī)器人的價(jià)格多少錢(qián)一個(gè)月 福建外呼電銷(xiāo)機(jī)器人加盟 自己做地圖標(biāo)注需要些什么

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

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

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

SHOW VARIABLES LIKE '%XA%'

如果innodb_support_xa的值是ON就說(shuō)明mysql已經(jīng)開(kāi)啟對(duì)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ù)指定一個(gè)id,xid 必須是一個(gè)唯一值。
$xid = uniqid("");
//兩個(gè)庫(kù)指定同一個(gè)事務(wù)id,表明這兩個(gè)庫(kù)的操作處于同一事務(wù)中
$dbtest1->query("XA START '$xid'");//準(zhǔn)備事務(wù)1
$dbtest2->query("XA START '$xid'");//準(zhǔn)備事務(wù)2
try {
  //$dbtest1
  $return = $dbtest1->query("UPDATE member SET name='唐大麥' WHERE id=1") ;
  if($return == false) {
    throw new Exception("庫(kù)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("庫(kù)dbtest1@172.20.101.18執(zhí)行update memberpoints操作失??!");
  }
  //階段1:$dbtest1提交準(zhǔn)備就緒
  $dbtest1->query("XA END '$xid'");
  $dbtest1->query("XA PREPARE '$xid'");
  //階段1:$dbtest2提交準(zhǔn)備就緒
  $dbtest2->query("XA END '$xid'");
  $dbtest2->query("XA PREPARE '$xid'");
  //階段2:提交兩個(gè)庫(kù)
  $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的性能很低。一個(gè)數(shù)據(jù)庫(kù)的事務(wù)和多個(gè)數(shù)據(jù)庫(kù)間的XA事務(wù)性能對(duì)比可發(fā)現(xiàn),性能差10倍左右

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

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

您可能感興趣的文章:
  • MySQL存儲(chǔ)表情時(shí)報(bào)錯(cuò):java.sql.SQLException: Incorrect string value:‘\xF0\x9F\x92\xA9\x0D\x0A...’的解決方法
  • 如何修改Xampp服務(wù)器上的mysql密碼(圖解)
  • 在mac上如何使用終端打開(kāi)XAMPP自帶的MySQL
  • xampp修改mysql默認(rèn)密碼的方法
  • ThinkPHP框架搭建及常見(jiàn)問(wèn)題(XAMPP安裝失敗、Apache/MySQL啟動(dòng)失?。?/li>
  • xampp中修改mysql默認(rèn)空密碼(root密碼)的方法分享
  • mysql的XA事務(wù)恢復(fù)過(guò)程詳解
  • 解決xampp自啟動(dòng)和mysql.sock問(wèn)題
  • MySQL數(shù)據(jù)庫(kù)是如何實(shí)現(xiàn)XA規(guī)范的

標(biāo)簽:陜西 昌都 北京 黔西 鄂爾多斯 駐馬店 荊門(mén) 梅河口

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《mysql跨庫(kù)事務(wù)XA操作示例》,本文關(guān)鍵詞  mysql,跨庫(kù),事務(wù),操作,示例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《mysql跨庫(kù)事務(wù)XA操作示例》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于mysql跨庫(kù)事務(wù)XA操作示例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章