执行一段事务,代码大致如下
try{
M()->startTrans();
//do something
} catch (Exception $ex) {
M()->rollback();
$this->error($ex->getMessage());
}
M()->commit();问题来了,当do something里只进行了查询,默认的链接是从服务器,但是事务的开启在主服务器上,所以回滚的时候直接提示不存在事务。经过尝试,在rollback()方法加入$this->initConnect(true);可以让链接先指向主服务器,解决此问题,修改的方法如下:
public function rollback() {
if ($this->transTimes > 0) {
$this->initConnect(true);
$result = $this->_linkID->rollback();
$this->transTimes = 0;
if(!$result){
$this->error();
return false;
}
}
return true;
}这样的话就改了核心代码,大家有没有更好的处理方法 最佳答案