Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

> instancje db, singleton? W przypadku baz danych
xerek
post
Post #1





Grupa: Zarejestrowani
Postów: 11
Pomógł: 0
Dołączył: 27.07.2008

Ostrzeżenie: (0%)
-----


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
Go to the top of the page
+Quote Post

Posty w temacie


Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 22.08.2025 - 15:11