mysql跨庫事務(wù)XA操作示例
本文實例講述了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)文章
mysql實現(xiàn)從導出數(shù)據(jù)的sql文件中只導入指定的一個表
這篇文章主要介紹了mysql實現(xiàn)從導出數(shù)據(jù)的sql文件中只導入指定的一個表,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11mysql中替代null的IFNULL()與COALESCE()函數(shù)詳解
這篇文章主要給大家介紹了關(guān)于mysql中替代null的IFNULL()與COALESCE()函數(shù)的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看看吧。2017-06-06innodb 庫的備份注意點(由phpmyadmin引起的解決方案)
新版本xampps 1.8.5 X64 集成了phpmyadmin最新版本(4.1.0), 可每次初始化安裝程序后, 進入phpmyadmin管理工具, 就會發(fā)現(xiàn)phpmyadmin高級功能失效, 一直在提示數(shù)據(jù)表不存在, 經(jīng)過再三的分析, 終于找到原因2013-12-12利用MySQL加密函數(shù)保護Web網(wǎng)站敏感數(shù)據(jù)的方法分享
如果您正在運行使用MySQL的Web應(yīng)用程序,那么它把密碼或者其他敏感信息保存在應(yīng)用程序里的機會就很大2012-03-03mysql_fetch_row()與mysql_fetch_array()的使用介紹
本篇文章是對mysql_fetch_row()與mysql_fetch_array()的使用進行了詳細的分析介紹,需要的朋友參考下2013-06-06