欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Codeigniter框架的更新事務(wù)(transaction)BUG及解決方法

 更新時(shí)間:2014年07月25日 11:05:15   投稿:junjie  
這篇文章主要介紹了Codeigniter框架的更新事務(wù)(transaction)BUG及解決方法,具體BUG和解決辦法在文中有詳細(xì)描述,需要的朋友可以參考下

由于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ù)就可以。

相關(guān)文章

最新評(píng)論