加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

如何使用OOP PHP避免打开与DB的多个连接

发布时间:2020-12-13 18:11:25 所属栏目:PHP教程 来源:网络整理
导读:我已经是一名超过4年的程序程序员,现在是时候开始研究OOP了.话虽如此,假设我需要在课堂上调用两种方法.每种方法都需要连接到DB,以便两次访问DB,这也会打开多个连接. 可以通过在应用程序层(构造函数?)中使用某种代码来避免这种情况,还是必须在数据库端设置连
我已经是一名超过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;
    }
}
你应该使用 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()来获取连接对象.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读