一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

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

由于ci事務判斷出錯回滾的條件是語句是否執行成功,而更新操作時,就算影響的條數為0,sql語句執行的結果過仍然為1,因為它執行成功了,只是影響的條數為0。

下面介紹解決這個問題的方法:

對于一次要執行許多的語句的事務

只需在更新操作下根據影響條數是否為0來決定是否會滾即可,下面假設第二條語句為更新操作。

復制代碼 代碼如下:
//采用 Codeigniter 事務的手動模式
    $this->db->trans_strict(FALSE);
    $this->db->trans_begin();
       
    $this->db->query('SELECT ...');//SELECT 操作無需特殊處理
    $this->db->query('INSERT ...');//INSERT 出錯會有 Codeigniter 自動處理
       
    $this->db->query('UPDATE ...');
    if (!$this->db->affacted_rows()) {//上面的 UPDATE 失敗則回滾
        $this->db->trans_rollback();
        //@todo 異常處理部分
        exit();//需要終止或跳出,以免下面的 SQL 代碼繼續執行!
    }
       
    $this->db->query('DELETE ...');
    if (!$this->db->affacted_rows()) {//上面的 DELETE 失敗則回滾
        $this->db->trans_rollback();
        //@todo 異常處理部分
        exit();//需要終止或跳出,以免下面的 SQL 代碼繼續執行!
    }
       
    $this->db->query('SELECT ...');//SELECT 操作無需特殊處理
    $this->db->query('INSERT ...');//INSERT 出錯會有 Codeigniter 自動處理
       
    if ($this->db->trans_status() === TRUE) {
        $this->db->trans_commit();
    } else {
        $this->db->trans_rollback();
        //@todo 異常處理部分
    }

如果一次執行的語句不是很多,可以在最后做一下判斷來決定回滾

若語句中沒有更新操作,用自動事務就可以。

php技術Codeigniter框架的更新事務(transaction)BUG及解決方法,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产一级特黄全黄毛片 | 亚洲不卡一区二区三区在线 | 国产最新精品 | 国产精品福利午夜一级毛片 | 免费精品国产自产拍在 | 思思玖玖玖在线精品视频 | 亚洲视频一区二区在线观看 | 国产性色视频在线高清 | 四虎免费入口 | 亚洲狠狠婷婷综合久久久久图片 | 免费人成网站尤物在线观看 | 91福利影院 | 国产91小视频在线观看 | 成人免费看黄网站yyy456 | 精品视频第一页 | 国产乱码精品一区二区三上 | www.一区二区三区 | 四虎国产永久在线精品免费观看 | 国产在线色视频 | 国内成人精品视频 | 青青草一区二区免费精品 | 在线观看资源 | 在线国产91 | 黄色大片免费看 | 亚洲最大的成人网 | 韩国一级毛片a级免观看 | 丁香六月婷婷精品免费观看 | 福利岛国深夜在线 | 精彩国产熟睡乱子伦午夜片 | 激情丁香小说 | 国产视频高清在线 | 无遮挡一级毛片 | 午夜激情视频专区在线观看网站大全 | 亚洲免费久久 | 狠狠大日本亚洲香蕉亚洲 | 毛片区| avav亚洲| 色网站综合 | 俄罗斯freexxxx性特大另类 | 韩国美女爽快一级毛片黄 | 自拍偷拍2019 |