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 :: mysqli_query всегда возвращает false

 PHP.SU

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


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

> Без описания
flamedeluxe
Отправлено: 09 Октября, 2013 - 12:43:03
Post Id


Новичок


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


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




Задача: вытащить из базы значение и сравнить
Проблема: mysqli_query всегда возвращает false
Ногами не пинать только учусь)

собственно код:
PHP:
скопировать код в буфер обмена
  1.  <?
  2. $link = $_GET['page'];
  3. if (!$link){
  4.         $link = 'index';
  5. }
  6.  
  7. $table = 'pages';
  8.  
  9. $connect = mysqli_connect("localhost", "root", "root", "test_base");
  10.  
  11. $query = sprintf("SELECT * FROM '%s' WHERE titleurl='%s'",
  12.                         mysqli_real_escape_string($connect, $table),
  13.                         mysqli_real_escape_string($connect, $link));
  14. $result = mysqli_query($connect, $query);
  15.  
  16.  
  17. if ($result==TRUE) {
  18.         echo "в базе есть совпадения";
  19. }
  20.         else echo "в базе нет совпадений"; ?>
 
 Top
Мелкий Супермодератор
Отправлено: 09 Октября, 2013 - 12:58:38
Post Id



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


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




Раз mysqli_query возвращает false, значит случилась ошибка запроса.
И если возвращает не false (а объект результата), это не значит, что вернулась хотя бы одна запись. Их может быть 0, но это успешно выполненный запрос.

Ошибку запроса поможет выяснить mysqli_error и, в целом ошибки - phpfaq.ru/debug

Ну а конкретно тут: имена таблиц и полей берутся в такие кавычки: `, а не в такие '


-----
PostgreSQL DBA
 
 Top
Alisandres
Отправлено: 09 Октября, 2013 - 13:01:36
Post Id



Новичок


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


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




Возвращает FALSE потому что в запросе произошла ошибка.

Попроще нельзя типа:

PHP:
скопировать код в буфер обмена
  1. $query = mуsql_query("SELECT * FROM table)
 
 Top
DelphinPRO
Отправлено: 09 Октября, 2013 - 13:06:52
Post Id



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


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


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




Вот переписал часть вашего кода.
PHP:
скопировать код в буфер обмена
  1. if ($result !== false) {
  2.     echo "Запрос выполнен успешно";
  3. } else {
  4.     echo "Произошла ошибка при выполнении запроса: ";
  5. }


Здесь только осталось дописать проверку на количество возвращенных записей в случае успешного запроса.


-----
Чем больше узнаю, тем больше я не знаю.
 
 Top
esterio
Отправлено: 09 Октября, 2013 - 13:36:24
Post Id



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


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


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




Мелкий пишет:
Ну а конкретно тут: имена таблиц и полей берутся в такие кавычки: `, а не в такие '

flamedeluxe пишет:
$query = sprintf("SELECT * FROM `%s` WHERE titleurl='%s'",
mysqli_real_escape_string($connect, $table),
mysqli_real_escape_string($connect, $link));

(Отредактировано автором: 09 Октября, 2013 - 13:36:54)

 
 Top
flamedeluxe
Отправлено: 09 Октября, 2013 - 15:05:24
Post Id


Новичок


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


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




Переделал получилось так:
Всем спасибо.
PHP:
скопировать код в буфер обмена
  1.  <?
  2. $query = mysqli_query($connect, "SELECT titleurl FROM `$table` WHERE `titleurl`='$link'");
  3.         $row = mysqli_fetch_assoc($query);
  4.                 if(is_array($row))
  5.                         {
  6.                                 $link=$row['titleurl'];
  7.                         }
  8.                 else $link='index';
  9.     mysqli_free_result($query);
  10. ?>

(Отредактировано автором: 09 Октября, 2013 - 17:03:41)

 
 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