我正在开发 CodeIgniter 的子查询库(链接到项目),它通过返回您可以使用的数据库对象而不是普通$this->db
对象来工作。
最初,我每次都在创建新的数据库对象:
$this->CI =& get_instance();
$db = $this->CI->load->database('', true);
但后来我意识到(或者更确切地说有人向我指出)这每次都会建立一个新的数据库连接!所以我决定尝试clone
对象而不是制造新对象。
我将代码更新为如下所示(链接到完整代码):
class Subquery{
var $CI, $db;
function __construct(){
$this->CI =& get_instance();
$this->db = $this->CI->db; // Default database connection
}
function start_subquery(){
$newDatabase = clone $this->db;
// some more code
return $newDatabase;
}
}
我对此进行了测试,它似乎有效,但我不确定这是否能解决问题。usingclone
是建立一个新的数据库连接,还是在内部使用引用并且只保留一个连接?