首页 >数据库 >mysql教程 >为什么 Codeigniter 事务中外部函数的错误不会触发回滚?

为什么 Codeigniter 事务中外部函数的错误不会触发回滚?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-11-03 04:53:30701浏览

Why do errors in external functions within Codeigniter transactions not trigger a rollback?

Codeigniter 事务

Codeigniter 通过其内置函数提供了处理数据库事务的无缝机制。这允许开发人员将多个数据库操作作为单个原子工作单元执行。

问题描述

但是,在 Codeigniter 中使用事务时,开发人员可能会遇到一个常见问题,即外部函数发生错误在事务块内调用不会触发回滚。

外部函数包含

要解决这个问题,重要的是要理解包含数据库操作的外部函数应该封装在模型中,而不是控制器。这可确保数据库交互在事务上下文中执行。

基于模型实现的代码示例

考虑以下代码示例:

<code class="php">// Model

class YourModel extends CI_Model {

    public function transactionExample($data, $id) {
        
        $this->db->trans_start();

        $this->db->insert('table_name', $data);

        // Updating data
        $this->db->where('id', $id);
        $this->db->update('table_name', $test); 

        $this->db->trans_complete();

        /*Optional*/

        if ($this->db->trans_status() === FALSE) {
            # Something went wrong.
            $this->db->trans_rollback();
            return FALSE;
        } 
        else {
            # Everything is Perfect. 
            # Committing data to the database.
            $this->db->trans_commit();
            return TRUE;
        }
    }
}</code>

关键注意事项

  • 默认情况下,Codeigniter 以严格模式运行所有事务。当启用严格模式时,如果任何一组事务失败,则所有组都将回滚。如果禁用严格模式,则每个组都会被独立处理,这意味着一组中的故障不会影响其他组。
  • 如果发生错误,trans_complete() 函数会自动回滚事务。或者,开发人员可以使用 trans_rollback() 和 trans_status() 函数手动处理错误。

Codeigniter 4 更新

在 Codeigniter 4 中,与事务相关的函数名称略有更改,如下所示如下:

Function Codeigniter 3 Codeigniter 4
Start Transaction trans_start() transBegin()
Complete Transaction trans_complete() transCommit()
Rollback Transaction trans_rollback() transRollback()
Transaction Status trans_status() transStatus()

以上是为什么 Codeigniter 事务中外部函数的错误不会触发回滚?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn