我对设计模式的概念相当陌生,我正在考虑使用依赖注入和多态(因为每个都适用)——但我有很多单例,虽然它们中的大多数可以很容易地改变,但我的 DBAL 不能。
DBAL 创建与数据库的连接的原因是——设置它自己的 PDO 对象。如果我将新的 DBAL 传递给每个需要它的类(很多),我将获得多个不必要的数据库连接。
类是这样的
class DB {
/**
* Hold the PDO object
* @var PDO
*/
private $_db;
/**
* Hold the last error messages
* @var string
*/
private $_error_message = NULL;
/**
* Hold the last error code
* @var int
*/
private $_error_code = NULL;
/**
* Connects to the database server and selects a database
*
* @param string $user MySQL database user
* @param string $password MySQL database password
* @param string $name MySQL database name
* @param string $host MySQL database host
* @return bool
*/
public function connect( $user, $password, $name, $host ) {
// Connect
try {
$this->_db = new PDO( "mysql:host=$host;dbname=$name", $user, $password );
} catch ( PDOException $e ) {
$this->_error_message = $e->getMessage();
$this->_error_code = $e->getCode();
return false;
}
return true;
}
// ...
}
?>
会有很多类继承这个类——处理这个的最好方法是什么?(我是设计模式的新手)