我已经是一名程序员,已经超过4年了,现在是时候开始研究OOP了。话虽如此,假设我需要在课堂上调用两种方法。每种方法都需要连接到DB,以便两次访问DB,这也会打开多个连接。 可以通过在应用程序层(构造函数?)中使用某种代码来避免这种情况,还是必须在数据库端设置连接池?而且只是为了踢,我不使用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;
}
}
答案 0 :(得分:6)
你应该使用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()
获取连接对象。
答案 1 :(得分:6)
您应该查看数据库连接的管理器类。然后,您可以在一个中心位置请求连接。如果已经存在打开的连接,则管理器可以返回该连接,而不是返回新连接。
这将是一种方法。关于如何实现这样的事情,有很多例子。已经有一些用于mysql和mssql。但你肯定可以扩展你的数据库。
答案 2 :(得分:1)
使用数据库图层。在这种情况下,迪比是一个很棒的图书馆。 http://dibiphp.com