当我在模型中加载数据库时,如何在 Codeigniter Profiler 中显示数据库查询?

2024-03-13

我的 Codeigniter 系统使用多个数据库。我不需要每个页面上的每个数据库,因此我在需要的模型中加载每个连接,然后在每个控制器中加载所需的模型。当我以这种方式加载内容时,探查器不会显示来自这些数据库的任何查询。

这是我在模型中加载数据库的方式:

$this->Companies_db = $this->load->database( 'companies', TRUE, TRUE );

我曾经在 MY_Controller() (核心控制器的扩展)中加载所有数据库。当我将它们加载到那里时,分析器工作正常。当我将它们加载到模型中时,它不显示任何数据库查询。

数据库查询正在该方法中编译_compile_queries() within system/libraries/Profiler.php。当我的数据库加载到模型中时,它们的对象不会加载到 CI 对象中。下面的代码是前几行_compile_queries()方法,这就是发生这种情况的地方。

foreach (get_object_vars($this->CI) as $CI_object)
    {
        if (is_object($CI_object) && is_subclass_of(get_class($CI_object), 'CI_DB') )
        {
            $dbs[] = $CI_object;
        }
    }

当我在模型中加载数据库时,如何让 CI 分析器显示我的查询?或者,更具体地说,当数据库加载到模型中时,如何将数据库对象加载到主 CI 对象中。


我将获取 CI 对象的一个​​实例并将数据库存储在那里,以便分析器也可以使用它。

class My_Model {
     private $Companies_db;

     public function __construct(){
           $this->Companies_db = $this->load->database( 'companies', TRUE, TRUE );

           // Pass reference of database to the CI-instance
           $CI =& get_instance();
           $CI->Companies_db =& $this->Companies_db;  
     }
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

当我在模型中加载数据库时,如何在 Codeigniter Profiler 中显示数据库查询? 的相关文章