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]   

> Без описания
Danxil
Отправлено: 07 Апреля, 2014 - 13:05:05
Post Id


Новичок


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


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




Есть код
PHP:
скопировать код в буфер обмена
  1.  
  2. $stmt = $this->db->prepare('SELECT name, id FROM user WHERE login = ? AND password = ?;');
  3.                        
  4. $stmt->execute(array($data->login, md5($data->password)));
  5.                        
  6. $response = $stmt->fetchObject();
  7.                        
  8. var_dump($response);
  9.  


В результате выводится flase, хотя такая строка в таблице точно есть. Захожу в таблицу логов - смотрю это запрос - SELECT name, id FROM user WHERE login = 'user1' AND password = '202cb962ac59075b964b07152d234b70'

Запускаю кго из консоли - все ок, выводится это поле. Почему в php выходит false ?
 
 Top
Panoptik
Отправлено: 07 Апреля, 2014 - 13:34:35
Post Id



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


Покинул форум
Сообщений всего: 2493
Дата рег-ции: Нояб. 2011  
Откуда: Одесса, Украина


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




посмотрите на ошибку

(Добавление)
и еще, используйте query вместо execute


-----
Just do it
 
 Top
ПТО
Отправлено: 07 Апреля, 2014 - 15:40:11
Post Id



Посетитель


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


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




PHP:
скопировать код в буфер обмена
  1. $sth = $this->db->query("SELECT name, id FROM user WHERE login = '$login' AND password = '$password';");
  2. return $sth->fetchAll(PDO::FETCH_ASSOC);


query быстрее при небольшом числе однотипных запросов,
используя переменные в одинарных кавычках, предварительно проверьте их на отсутствие кавычек
Выполняйте fetchAll для получения двумерного массива (строки, поля) данных
 
 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