2

我试图找出最好的办法是让程序中的多个对象连接到数据库。

我创建了一个带有静态连接变量的类。这似乎意味着只打开一个连接并且所有对象共享它。

class Database {
    public static $mysql;
    function __construct() {
        if (!isset(self::$mysql)) {
            echo "Make static connection\n";
            self::$mysql = new mysqli("localhost", "gamalert", "c45ualty", "events");
            if (self::$mysql->connect_errno) {
                echo "Failed to connect to MySQL: (" . $this->mysql->connect_errno . ") " . self::$mysql->connect_error;
            }
            echo self::$mysql->host_info . "\n";
        }
    }
}

一个普通的对象版本。这将为每个使用它的对象创建一个新连接。

class Database {
    public $mysql;
    function __construct() {
        if (!isset($this->mysql)) {
            echo "Make connection\n";
            $this->mysql = new mysqli("localhost", "gamalert", "c45ualty", "events");
            if ($this->mysql->connect_errno) {
                echo "Failed to connect to MySQL: (" . $this->mysql->connect_errno . ") " . $this->mysql->connect_error;
            }
            echo $this->mysql->host_info . "\n";
        }
    }

我想知道首选的选项是什么?我计划稍后测试性能差异。

4

1 回答 1

0

连接数据库是非常昂贵的操作,您应该避免创建多个连接。所以你应该放弃你的正常对象版本。

带有静态变量的选项更好,但并不理想。您需要记住在每个类中复制此构造函数。如果你想在这方面改变什么?然后,您需要打开所有课程并在任何地方进行更改。

我认为,你应该创建抽象对象Database并用你的类扩展它。

abstract class Database {
    protected static $mysql;
    function __construct() {
        if (!isset(self::$mysql)) {
            echo "Make static connection\n";
            self::$mysql = new mysqli("localhost", "gamalert", "c45ualty", "events");
            if (self::$mysql->connect_errno) {
                echo "Failed to connect to MySQL: (" . $this->mysql->connect_errno . ") " . self::$mysql->connect_error;
            }
            echo self::$mysql->host_info . "\n";
        }
    }
}

然后创建将使用此连接的新对象很简单:

class ExtDatabase extends Database {
    public function __construct() {
        echo "Executing parent...";
        parent::__construct();
    }

    public function hostInfo() {
        //no problem with using connection there
        echo self::$mysql->host_info . "\n";
    }
}

但是......它也不是很好的选择。最好将 Singleton 与连接和抽象数据库类一起使用。

于 2012-06-29T09:01:37.833 回答