本文實例講述了mysql跨庫事務XA操作。分享給大家供大家參考,具體如下:
前一段時間在工作中遇到了跨庫事務問題,后來在網(wǎng)上查詢了一下,現(xiàn)在做一下整理和總結。
1、首先要確保mysql開啟XA事務支持
SHOW VARIABLES LIKE '%XA%'
如果innodb_support_xa的值是ON就說明mysql已經(jīng)開啟對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的性能很低。一個數(shù)據(jù)庫的事務和多個數(shù)據(jù)庫間的XA事務性能對比可發(fā)現(xiàn),性能差10倍左右
更多關于MySQL相關內(nèi)容感興趣的讀者可查看本站專題:《MySQL事務操作技巧匯總》、《MySQL查詢技巧大全》、《MySQL存儲過程技巧大全》、《MySQL數(shù)據(jù)庫鎖相關技巧匯總》及《MySQL常用函數(shù)大匯總》
希望本文所述對大家MySQL數(shù)據(jù)庫計有所幫助。
您可能感興趣的文章:- MySQL存儲表情時報錯:java.sql.SQLException: Incorrect string value:‘\xF0\x9F\x92\xA9\x0D\x0A...’的解決方法
- 如何修改Xampp服務器上的mysql密碼(圖解)
- 在mac上如何使用終端打開XAMPP自帶的MySQL
- xampp修改mysql默認密碼的方法
- ThinkPHP框架搭建及常見問題(XAMPP安裝失敗、Apache/MySQL啟動失?。?/li>
- xampp中修改mysql默認空密碼(root密碼)的方法分享
- mysql的XA事務恢復過程詳解
- 解決xampp自啟動和mysql.sock問題
- MySQL數(shù)據(jù)庫是如何實現(xiàn)XA規(guī)范的