|
由于ci事務(wù)判斷出錯(cuò)回滾的條件是語(yǔ)句是否執(zhí)行成功,而更新操作時(shí),就算影響的條數(shù)為0,sql語(yǔ)句執(zhí)行的結(jié)果過(guò)仍然為1,因?yàn)樗鼒?zhí)行成功了,只是影響的條數(shù)為0。
下面介紹解決這個(gè)問(wèn)題的方法:
對(duì)于一次要執(zhí)行許多的語(yǔ)句的事務(wù)
只需在更新操作下根據(jù)影響條數(shù)是否為0來(lái)決定是否會(huì)滾即可,下面假設(shè)第二條語(yǔ)句為更新操作。
復(fù)制代碼 代碼如下:
//采用 Codeigniter 事務(wù)的手動(dòng)模式
$this->db->trans_strict(FALSE);
$this->db->trans_begin();
$this->db->query('SELECT ...');//SELECT 操作無(wú)需特殊處理
$this->db->query('INSERT ...');//INSERT 出錯(cuò)會(huì)有 Codeigniter 自動(dòng)處理
$this->db->query('UPDATE ...');
if (!$this->db->affacted_rows()) {//上面的 UPDATE 失敗則回滾
$this->db->trans_rollback();
//@todo 異常處理部分
exit();//需要終止或跳出,以免下面的 SQL 代碼繼續(xù)執(zhí)行!
}
$this->db->query('DELETE ...');
if (!$this->db->affacted_rows()) {//上面的 DELETE 失敗則回滾
$this->db->trans_rollback();
//@todo 異常處理部分
exit();//需要終止或跳出,以免下面的 SQL 代碼繼續(xù)執(zhí)行!
}
$this->db->query('SELECT ...');//SELECT 操作無(wú)需特殊處理
$this->db->query('INSERT ...');//INSERT 出錯(cuò)會(huì)有 Codeigniter 自動(dòng)處理
if ($this->db->trans_status() === TRUE) {
$this->db->trans_commit();
} else {
$this->db->trans_rollback();
//@todo 異常處理部分
}
如果一次執(zhí)行的語(yǔ)句不是很多,可以在最后做一下判斷來(lái)決定回滾
若語(yǔ)句中沒(méi)有更新操作,用自動(dòng)事務(wù)就可以。
php技術(shù):Codeigniter框架的更新事務(wù)(transaction)BUG及解決方法,轉(zhuǎn)載需保留來(lái)源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。