mysql跨庫事務XA操作示例
發(fā)布日期:2022-03-12 14:31 | 文章來源:CSDN
本文實例講述了mysql跨庫事務XA操作。分享給大家供大家參考,具體如下:
前一段時間在工作中遇到了跨庫事務問題,后來在網上查詢了一下,現在做一下整理和總結。
1、首先要確保mysql開啟XA事務支持
SHOW VARIABLES LIKE '%XA%'
如果innodb_support_xa的值是ON就說明mysql已經開啟對XA事務的支持了。
如果不是就執(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事務指定一個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執(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的性能很低。一個數據庫的事務和多個數據庫間的XA事務性能對比可發(fā)現,性能差10倍左右
更多關于MySQL相關內容感興趣的讀者可查看本站專題:《MySQL事務操作技巧匯總》、《MySQL查詢技巧大全》、《MySQL存儲過程技巧大全》、《MySQL數據庫鎖相關技巧匯總》及《MySQL常用函數大匯總》
希望本文所述對大家MySQL數據庫計有所幫助。
版權聲明:本站文章來源標注為YINGSOO的內容版權均為本站所有,歡迎引用、轉載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網站,禁止在非www.sddonglingsh.com所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內容來源于網友推薦、互聯網收集整理而來,僅供學習參考,不代表本站立場,如有內容涉嫌侵權,請聯系alex-e#qq.com處理。
相關文章
上一篇:
mysql show操作簡單示例
下一篇: