中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

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

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

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

對于一次要執(zhí)行許多的語句的事務

只需在更新操作下根據(jù)影響條數(shù)是否為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 代碼繼續(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 操作無需特殊處理
    $this->db->query('INSERT ...');//INSERT 出錯會有 Codeigniter 自動處理
       
    if ($this->db->trans_status() === TRUE) {
        $this->db->trans_commit();
    } else {
        $this->db->trans_rollback();
        //@todo 異常處理部分
    }

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

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

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

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

主站蜘蛛池模板: 欧美一区二 | 亚洲最新在线视频 | 精品免费 | 国产成人一区二区三区 | 午夜精品一区二区三区在线观看 | 少妇性l交大片免费一 | 在线欧美日韩 | av天天操 | 亚洲欧洲一区二区 | 日本三级全黄三级三级三级口周 | 久久久久久国产精品免费免费狐狸 | 亚洲精品99 | 中国毛片免费 | 午夜精品视频在线观看 | 免费黄色特级片 | 国产三级日本三级 | 一级片免费视频 | av网站免费在线观看 | 亚洲日产精品 | 午夜免费在线 | 国产2区 | a在线视频观看 | 亚洲免费在线 | 欧美日韩在线视频一区二区 | 久久久久久亚洲 | 黄色网毛片 | av在线免费观看网址 | 日韩电影中文字幕 | 国产免费一区二区三区 | 视频一区二区三区在线观看 | 青青草原综合久久大伊人精品 | 久久噜噜噜精品国产亚洲综合 | 青青久草| 日韩毛片免费视频 | 亚洲 精品 综合 精品 自拍 | 奇米影视在线 | 欧美一级二级在线观看 | 亚洲一区 | 久久亚洲一区 | 色综合天天网 | 精品美女久久久 |