Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Обертка PDO

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
resik
Отправлено: 26 Апреля, 2016 - 23:17:56
Post Id



Новичок


Покинул форум
Сообщений всего: 51
Дата рег-ции: Дек. 2013  


Помог: 0 раз(а)




Здравствуйте.

Может кто пояснить смысл двух разных реализация обертки для PDO.
В примерах опущены блоки try catch и прочее.

Пример 1:
CODE (htmlphp):
скопировать код в буфер обмена
  1.  
  2. class DB extends PDO
  3. {
  4.         public function __construct()
  5.         {
  6.                 parent::__construct( $dsn );
  7.         }
  8.        
  9.         public function query( $sql )
  10.         {
  11.                 return parent::query( $sql );
  12.         }
  13. }
  14.  
  15. $db = new DB();
  16.  
  17. $db->query( /*SQL*/ );
  18.  


Пример 2:
CODE (htmlphp):
скопировать код в буфер обмена
  1.  
  2. class DB
  3. {
  4.         private $_instance;
  5.        
  6.         public function __construct()
  7.         {
  8.                 $this->_instance = new PDO( $dsn );
  9.         }
  10.        
  11.         public function query( $sql )
  12.         {
  13.                 return $this->_instance->query( $sql );
  14.         }
  15. }
  16.  
  17. $db = new DB();
  18.  
  19. $db->query( /*SQL*/ );
  20.  
 
 Top
Ch_chov
Отправлено: 27 Апреля, 2016 - 08:56:12
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2121
Дата рег-ции: Июль 2008  
Откуда: из города


Помог: 90 раз(а)




Первая обёртка реализованна через наследование, вторая через фабрику. В текущем виде обе реализации не имеют никакого смысла.
 
 Top
resik
Отправлено: 27 Апреля, 2016 - 08:59:58
Post Id



Новичок


Покинул форум
Сообщений всего: 51
Дата рег-ции: Дек. 2013  


Помог: 0 раз(а)




Ch_chov пишет:
Первая обёртка реализованна через наследование, вторая через фабрику. В текущем виде обе реализации не имеют никакого смысла.


Какой стиль использовать лучше и почему, подскажите, если не сложно.
 
 Top
Ch_chov
Отправлено: 27 Апреля, 2016 - 09:55:38
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2121
Дата рег-ции: Июль 2008  
Откуда: из города


Помог: 90 раз(а)




От задачи зависит. Для чего вам вообще обёртка?
 
 Top
resik
Отправлено: 27 Апреля, 2016 - 10:14:04
Post Id



Новичок


Покинул форум
Сообщений всего: 51
Дата рег-ции: Дек. 2013  


Помог: 0 раз(а)




Ch_chov пишет:
От задачи зависит. Для чего вам вообще обёртка?


Для добавления своих методов класса к дополнению уже существующих от PDO, обработка исключений, логирование ошибок, сбор запросов и все такое.
 
 Top
and_07
Отправлено: 27 Апреля, 2016 - 11:05:44
Post Id


Гость


Покинул форум
Сообщений всего: 91
Дата рег-ции: Сент. 2012  


Помог: 3 раз(а)




Ch_chov пишет:
Первая обёртка реализованна через наследование, вторая через фабрику.


не понял причем тут фабрика
тут наследование и композиция

+ на мой взгляд композиция предпочтительней наследования
а так на вкус и цвет ...

(Отредактировано автором: 27 Апреля, 2016 - 11:15:07)

 
 Top
Ch_chov
Отправлено: 27 Апреля, 2016 - 13:37:50
Post Id



Постоянный участник


Покинул форум
Сообщений всего: 2121
Дата рег-ции: Июль 2008  
Откуда: из города


Помог: 90 раз(а)




and_07 пишет:
тут наследование и композиция

Да,точно.

resik пишет:
обработка исключений, логирование ошибок, сбор запросов и все такое

Оба метода подходят. Но старайтесь не пихать в слой базы данных логику приложения.
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB