Форум программистов, компьютерный форум, киберфорум
PHP: ООП
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/39: Рейтинг темы: голосов - 39, средняя оценка - 4.97
 Аватар для Sanu0074
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5

Как использовать экземпляр PDO в своём классе?

24.01.2012, 01:59. Показов 7114. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вот я соединяюсь с базой:
PHP
1
$dbh = new PDO("mysql:host=$host;dbname=$db_name",$user,$pass);
если использовать $dbh вне своего класса, то всё пашет, а если я создал класс и пытаюсь чтото извлечь из базы через $dbh - то выдает ошибку:

PHP
1
2
3
4
5
6
7
8
class MyClass
{
    public function get_data()
    {
        $q = $dbh->query("SELECT `id` FROM table ");
        $q_row = $q->fetch();
           }
}
Ошибка:
Fatal error: Call to a member function query() on a non-object in W:\home\localhost\www\index.php on line 26

Как правильно использовать экземпляр PDO в своём классе???
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
24.01.2012, 01:59
Ответы с готовыми решениями:

Как правильно использовать экземпляр PDO в своём классе?
Читал тему, но приведенный вариант в самом конце не подходит. Поэтому вынес подключние к базе в отдельный класс, где в конструкторе идет...

Создать экземпляр класса Graphics для метода в своём классе
Всем привет.Делаю графический редактор,нужно,чтобы отрисовывались на контроле picturebox линии из списка lines.Для этого создал класс...

Использовать канвас в своём классе
unit Clock; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms, Dialogs, ExtCtrls; ...

12
 Аватар для crautcher
2450 / 2301 / 597
Регистрация: 27.05.2011
Сообщений: 7,844
24.01.2012, 11:52
а где в класе ты объявляешь этот обьект?
0
 Аватар для Sanu0074
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
24.01.2012, 12:09  [ТС]
Цитата Сообщение от crautcher Посмотреть сообщение
а где в класе ты объявляешь этот обьект?
5я строка!
0
 Аватар для crautcher
2450 / 2301 / 597
Регистрация: 27.05.2011
Сообщений: 7,844
24.01.2012, 12:13
Цитата Сообщение от Sanu0074 Посмотреть сообщение
5я строка!
в 5ой строке ты используешь объект $dbh , а где он задаётся если вне класа то надо его объявить
global $dbh;
0
 Аватар для Sanu0074
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
24.01.2012, 12:35  [ТС]
Цитата Сообщение от crautcher Посмотреть сообщение
в 5ой строке ты используешь объект $dbh , а где он задаётся если вне класа то надо его объявить
global $dbh;
ничего не изменилось, ошибка прежняя..
0
 Аватар для crautcher
2450 / 2301 / 597
Регистрация: 27.05.2011
Сообщений: 7,844
24.01.2012, 13:24
выложите весь код , непонятно где и что у вас
1
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
24.01.2012, 16:49
Sanu0074, В приведенном коде с классом переменная $dbh в строке 5 - всего лишь локальная переменная внутри метода get_data(), которой не существует (в результате чего появляется Notice о несуществующей переменной, и в качестве её значения появляется null).
1
163 / 163 / 9
Регистрация: 08.01.2011
Сообщений: 850
24.01.2012, 17:17
PHP
1
2
3
4
5
6
7
8
9
class MyClass
{
        public function get_data()
        {
                $dbh = new PDO("mysql:host=$host;dbname=$db_name",$user,$pass);
                $q = $dbh->query("SELECT `id` FROM table ");
                $q_row = $q->fetch();
           }
}
Вот теперь $dbh существует и в зоне видимости

Добавлено через 36 секунд
И вообще, в PHP 5.4 register_globals помрут окончательно, так что хватит плодить такие ошибки.

Добавлено через 51 секунду
Никаких global! Категорически!
1
 Аватар для Sanu0074
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
24.01.2012, 18:55  [ТС]
Цитата Сообщение от KoIIIeY Посмотреть сообщение
PHP
1
2
3
4
5
6
7
8
9
class MyClass
{
        public function get_data()
        {
                $dbh = new PDO("mysql:host=$host;dbname=$db_name",$user,$pass);
                $q = $dbh->query("SELECT `id` FROM table ");
                $q_row = $q->fetch();
           }
}
сделал так, теперь ошибка такая:
Fatal error: Uncaught exception 'PDOException' with message 'SQLSTATE[28000] [1045] Access denied for user ''@'localhost' (using password: NO)' in W:\home\localhost\www\index.php:26 Stack trace: #0 W:\home\localhost\www\index.php(26): PDO->__construct('mysql:host=;dbn...', NULL, NULL) #1 W:\home\localhost\www\index.php(147): Index->get_news() #2 {main} thrown in W:\home\localhost\www\index.php on line 26

Добавлено через 11 минут
когда использую не PDO а функции mysql_connect и mysql_select_db то всё работает...
0
 Аватар для Vovan-VE
13210 / 6599 / 1041
Регистрация: 10.01.2008
Сообщений: 15,069
24.01.2012, 19:02
Sanu0074, Переменные $user и $pass в 5й строке теперь локальны и не определены.

Включите отображение всех ошибок.
1
 Аватар для Sanu0074
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
25.01.2012, 02:48  [ТС]
Цитата Сообщение от Vovan-VE Посмотреть сообщение
Sanu0074, Переменные $user и $pass в 5й строке теперь локальны и не определены.

Включите отображение всех ошибок.
О! всё понял) спасибо

Добавлено через 7 часов 16 минут
Получается, что в каждой функции класса, необходимо делать:
PHP
1
$dbh = new PDO("mysql:host=$host;dbname=$db_name",$user,$pass);
или можно както 1 раз в классе это сделать а потом применять ко всем функциям???
0
 Аватар для crautcher
2450 / 2301 / 597
Регистрация: 27.05.2011
Сообщений: 7,844
25.01.2012, 11:40
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
class Myclass{
public $dbh;
 
 function __construct($host,$db_name,$user,$pass){
 $this -> dbh = new PDO("mysql:host=$host;dbname=$db_name",$user,$pass);
 }
 
 function blabla(){
 $this -> dbh -> query ...
 }
}
 
$myObj = new Myclass('82.132.143.202' , 'mybase' , 'someusr' , 'somepw');
1
 Аватар для Sanu0074
59 / 59 / 16
Регистрация: 14.06.2010
Сообщений: 1,190
Записей в блоге: 5
25.01.2012, 13:05  [ТС]
Цитата Сообщение от crautcher Посмотреть сообщение
PHP
1
2
3
4
5
6
7
8
9
10
11
12
13
class Myclass{
public $dbh;
 
 function __construct($host,$db_name,$user,$pass){
 $this -> dbh = new PDO("mysql:host=$host;dbname=$db_name",$user,$pass);
 }
 
 function blabla(){
 $this -> dbh -> query ...
 }
}
 
$myObj = new Myclass('82.132.143.202' , 'mybase' , 'someusr' , 'somepw');
спасибо =)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
25.01.2012, 13:05
Помогаю со студенческими работами здесь

Как использовать объект класса, созданого в определеном классе, в другом классе
У меня такой вопрос,как использовать объект класса,созданого в определеном классе,в другом классе.У меня есть объект pl класса Player,это...

Как использовать информацию парсированую в 1 классе в другом классе
имеются 2 класса , объясните плз в чём ошибка using System; using System.Collections.Generic; using System.Linq; using System.Text;...

Как объявить компонент в своём классе?
Здравствуйте! Не могу найти примеров, разобраться самостоятельно не получается. Допустим мне нужно сделать свой класс который - из...

Как создать событие в своём классе
Есть класс Class1 Есть его экземпляр var A:Class1 = new Class1(); Как сделать чтобы у переменной A было событие onMessage, чтобы я...

Как создать в своем классе событие ?
Познакомился с Qt , там написано как можно связать событие с обработчиком события , как связать обработчик события с нескольким событиями ,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru