代码之家  ›  专栏  ›  技术社区  ›  sdot257

如何避免使用oop-php打开与数据库的多个连接

  •  7
  • sdot257  · 技术社区  · 15 年前

    我做程序程序员已经4年多了,现在是时候开始研究OOP了。这么说,假设我需要在我的类中调用两个方法。每个方法都需要一个到数据库的连接,所以这是到数据库的两次访问,这也会打开多个连接。 可以通过在应用程序层(构造函数)中使用某种类型的代码来避免这种情况吗?或者必须在数据库端设置连接池?只是为了好玩,我不使用MySQL;我使用的是MongoDB和CodeIgniter。

    这是我到目前为止所拥有的,不确定它是否是理想的用途?

    以下是我设置数据库信息的位置:

    数据库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;
        }
    }
    
    3 回复  |  直到 15 年前
        1
  •  6
  •   Sergey Eremin    15 年前

    你应该使用 singleton pattern

    编辑: 按照您的方式,可以多次调用“连接”,这意味着重新连接。

    单例实现通常意味着您必须使构造函数私有/受保护,并定义一个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() 获取连接对象。

        2
  •  6
  •   spinon    15 年前

    您应该查看一个管理器类来查找您的DB连接。然后您可以在一个中心位置请求连接。如果已经存在打开的连接,管理器可以返回该连接,而不是返回新连接。

    这将是一种方法。关于如何实现类似的东西,有很多例子。已经有一些用于mysql和mssql。但是你可以为你的数据库做扩展。

        3
  •  1
  •   J. K.    15 年前

    使用数据库层。在这种情况下,迪比是一个伟大的图书馆。 http://dibiphp.com