Witam serdecznie
Czytajac wasze posty czesto natrafialem na stwierdzenie ze singleton jest zlym wzorcem projektowym wykorzystywanym przy tworzeniu instancji klasy db. Jednak nigdzie nie moglem doszukac sie argumentów przemawiajacych za tym stwierdzeniem.. Podam przyklad:
-----Klasa DataBase-----
private $connect;
private function __construct() {
$conf=parse_ini_file('config/DsnConfig.ini',true);
$dsn=$conf[Data][DSN];
$this->connect=DB::connect($dsn);
if(DB::isError($this->connect)) {
throw new Exception($this->connect->getMessage(), $this->connect->getCode());
}
$this->connect->setFetchMode(DB_FETCHMODE_ASSOC);
//$db=$this->select('Set CHARSET UTF8');
}
static public function instance() {
static $objDB;
if(!isset($objDB)) {
$objDB=new Database();
}
return $objDB;
}
Powyzszy kod zapewnia nam to ze nie utworzymy wiecej niz jednego egzemplarza klasy Database. Zapewni nam to porzadzek w kodzie i w strukturze aplikacji a takze w jej wydajnoci bo przeciez utrzymujemy tylko jedno polaczenie z baza danych.. Teraz stawiam pytanie co jest w tym zlego ?
Minusem jest na pewno to ze mamy sztywno okreslone, że uzywamy jednej bazy danych. Chciałbym uslyszec wasze opinie na ten temat..
pozdrawiam