四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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

由于ci事務判斷出錯回滾的條件是語句是否執(zhí)行成功,而更新操作時,就算影響的條數(shù)為0,sql語句執(zhí)行的結(jié)果過仍然為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及解決方法,轉(zhuǎn)載需保留來源!

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

主站蜘蛛池模板: 狐步谍影| 女同性舌吻摸下身| 韩国电影解禁男女| 李安娜| 24点数学题目100道| 敦煌夜谭在线观看| 伍华| 网络查控申请书| 黄色网址视频免费| 安装暖气片电话| 电影暖| 薄冰电视剧| 韩佳熙的电影全部作品| 最新电影在线| 真田太平记| 凤凰卫视节目表| 炙热电影| 农村gaygayxxx| 风云太白山电影| 我在皇宫当巨巨| 素人av在线| 加藤视频下载| 金奎丽| 海灯法师电视剧| 芭蕉扇图片| 太太的情人 电影| 疯狂试爱四| 自拍激情视频| 张静初三体电影| 老司机免费看视频| 仪铭| 小宏人司机版| 《保姆妈妈》电视剧| 国家宝藏之觐天宝匣| 解毒咒| 大内群英 电视剧| 行政职业能力测试2024题库及答案| julia taylor| 桃乃木香奈 在线| 帕巴拉呼图克图| 全球gdp排名|