在我的项目中,我使用2个数据库,所以在某些部分,当我需要使用辅助数据库时,我使用:
$newDB = $this->load->database("otherDB", true);
或
$CI =& get_instance();
$newDB = $CI->load->database("otherDB",true);
获取de instance.
但是当我这样做时,ion_auth无法保持与原始数据库的连接并抛出2个错误:
Call to a member function result()
在get_users_groups函数中,并且:
Trying to get property of non-object
在link_menu_acl函数。
我尝试强制重新加载默认数据库,但只"修复"了第一个问题。
我的猜测是,当它加载辅助数据库时,ion_auth失去了与默认数据库的连接,但我不知道如何保持它或重新连接它以使用两个数据库。
好的,问题是主数据库和辅助数据库在持久连接配置中设置了"true",所以似乎ion_auth "找到"辅助连接并尝试对其进行查询,并且可能因为"未知错误"它返回false而不是对象。
将从数据库"pconnect"改为"false",问题就解决了。
我只是不明白为什么它没有抛出"no table in database"错误,而只是"false"