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 :: Подключение к базе с помощью ООП

 PHP.SU

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


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

> Описание: Подскажите пожалуйста
tuubish
Отправлено: 09 Января, 2015 - 18:33:09
Post Id


Новичок


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


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




Класс DataBase:
PHP:
скопировать код в буфер обмена
  1.  
  2. <?PHP
  3.         class DataBase{
  4.                 private $host = 'localhost';
  5.                 private $dbuser = 'db_user';
  6.                 private $dbpass = 'password';
  7.                 private $dbname = 'db_name';
  8.                
  9.                 function __construct($host, $dbuser, $dbpass, $dbname){
  10.                         $this->host = $host;
  11.                         $this->dbuser = $dbuser;
  12.                         $this->dbpass = $dbpass;
  13.                         $this->dbname = $dbname;
  14.                 }
  15.                
  16.                 public function setDb($db){
  17.                         try{
  18.                                 $conn = new PDO("mysql:host = $host; $dbname", $dbuser, $dbpass);
  19.                                 $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
  20.                                 echo "Connected successfully!";
  21.                         }
  22.                         catch(PDOException $e){
  23.                                 echo "Connection failed" . $e->getMessage();
  24.                         }
  25.                 }
  26.         }
  27.  


Создание объекта и вызов:
PHP:
скопировать код в буфер обмена
  1.  
  2. $db = new DataBase($host, $dbuser, $dbpass, $dbname);
  3.  


Подскажите пожалуйста, правильно ли так подключать БД?
 
 Top
RickMan
Отправлено: 09 Января, 2015 - 23:15:59
Post Id


Участник


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


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




Ты просто создал экземпляр класса и закинул в него данные для коннекта, но ты еще не подключился к БД. Вызови метод setDb и передай в него название БД.
 
 Top
tuubish
Отправлено: 28 Января, 2015 - 07:27:15
Post Id


Новичок


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


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




RickMan
Спасибо за совет!
Но при вызове метода выводит ошибку
Warning: Missing argument 1 for DataBase::__construct(), called in /var/www/vhosts/tuubish.tk/demo. tuubish.tk/oop.php on line 29 and defined in /var/www/vhosts/tuubish.tk/demo. tuubish.tk/database.php on line 8

Данная линия именно в конструкторе.

(Отредактировано автором: 28 Января, 2015 - 07:28:38)

 
 Top
and_07
Отправлено: 28 Января, 2015 - 09:21:49
Post Id


Гость


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


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




PHP:
скопировать код в буфер обмена
  1.  
  2. ...
  3.   public function setDb(){
  4.                         try{
  5.                                 $conn = new PDO("mysql:host = $this->host; $this->dbname", $this->dbuser, $this->dbpass);
  6. ...
  7. ...
  8. ...
  9. $db = new DataBase($host, $dbuser, $dbpass, $dbname);
  10. $db->setDb();
  11.  

(Отредактировано автором: 28 Января, 2015 - 09:26:01)

 
 Top
DelphinPRO
Отправлено: 28 Января, 2015 - 17:09:38
Post Id



Активный участник


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


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






Подключение сохраняется в локальную переменную, которая будет уничтожена по завершении метода. Вы подключились, но ничего не сможете сделать с этим подключением.


-----
Чем больше узнаю, тем больше я не знаю.
 
 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