我已经是一名超过4年的程序程序员,现在是时候开始研究OOP了.话虽如此,假设我需要在课堂上调用两种方法.每种方法都需要连接到DB,以便两次访问DB,这也会打开多个连接.
可以通过在应用程序层(构造函数?)中使用某种代码来避免这种情况,还是必须在数据库端设置连接池?而且只是为了踢,我不使用 mysql;我正在使用mongodb和codeigniter.
可以通过在应用程序层(构造函数?)中使用某种代码来避免这种情况,还是必须在数据库端设置连接池?而且只是为了踢,我不使用 mysql;我正在使用mongodb和codeigniter.
这是我到目前为止所做的,不确定它是否适合使用?
这是我设置数据库信息的地方:
database_conn.PHP
class Database_Conn extends Model { function _connect() { $m = new Mongo("localhost:27017",array("persist"=>"x")); $db = $m->selectDB( "foo" ); return $db; } }
样本模型文件
class Home_model extends Model { public function __construct() { // Establish connection to "profiles" table $this->db_conn = Database_Conn::_connect()->selectCollection( "profiles" ); } function getMyProfile($username) { $data = $this->db_conn->findOne(array("username" => $username) ); return $data; } function getAll() { $data = $this->db_conn->find(); return $data; } }
你应该使用
singleton pattern
编辑:
你这样做的方式,可以多次调用_connect,这意味着重新连接.
单例实现通常意味着您必须使构造函数private / protected并定义一个getInstance方法,该方法在第一次调用时创建连接并在以后的调用中返回创建的连接.
这就是我要做的:
class Database_Conn extends Model { static protected $_instance; protected $db = null; final protected function __construct() { $m = new Mongo("localhost:27017",array("persist"=>"x")); $this->db = $m->selectDB( "foo" ); } static public function getInstance() { if (!(self::$_instance instanceof self)) { self::$_instance = new self(); } return self::$_instance; } public function getConnection() { return $this->db; } final protected function __clone() { } }
然后使用Database_Conn :: getInstance() – > getConnection()来获取连接对象.