我的 Codeigniter 系统使用多个数据库。我不需要每个页面上的每个数据库,因此我将模型中的每个连接加载到需要的地方,然后在每个控制器中加载所需的模型。当我以这种方式加载内容时,分析器不会显示来自这些数据库的任何查询。
这就是我在模型中加载数据库的方式:
$this->Companies_db = $this->load->database( 'companies', TRUE, TRUE );
我曾经在 MY_Controller() (核心控制器的扩展)中加载我的所有数据库。当我在那里加载它们时,分析器工作正常。当我将它们加载到我的模型中时,它不会显示任何数据库查询。
数据库查询正在编译中的方法_compile_queries()
中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 对象中。