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 Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


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

> Описание: в чем ошибка?(
b0d
Отправлено: 11 Января, 2013 - 12:02:42
Post Id


Новичок


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


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




День добрый, подскажите пожалуйста, в чем моя ошибка ?
PHP:
скопировать код в буфер обмена
  1. <div id="content">
  2. <?PHP
  3.  $result=mysql_query("Select body FROM pages WHERE page='page1.php'",$link);
  4. $myrow=mysql_fetch_array($result);
  5. printf("%s", $myrow['body']);
  6. ?>
  7. </div>

В таблице pages находится 2 значения, id(номер статьи) и body(текст статьи).
Заранее благодарен!
 
 Top
vvn
Отправлено: 11 Января, 2013 - 12:05:59
Post Id


Новичок


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


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




А вы подключились к серверу БД и выбрали базу с которой запрашиваете данные?
 
 Top
b0d
Отправлено: 11 Января, 2013 - 12:10:09
Post Id


Новичок


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


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




Простите, да, подключил прежде всего:
 
 Top
vvn
Отправлено: 11 Января, 2013 - 12:15:08
Post Id


Новичок


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


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




А можно вас попросить показать содержимое bd.php. Также, я бы рекомендовал использовать require вместо и include для подключения к бд (если оно критично)
 
 Top
b0d
Отправлено: 11 Января, 2013 - 12:19:54
Post Id


Новичок


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


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




PHP:
скопировать код в буфер обмена
  1. <?PHP
  2.         $link = mysql_connect ("localhost","root","");
  3.         mysql_select_db ("zpi",$link);
  4.         ?>

(Добавление)
текст ошибки:
Warning: mysql_fetch_array() expects parameter 1 to be resource, boolean given in:

вот на эту строку указывает:
 
 Top
vvn
Отправлено: 11 Января, 2013 - 12:30:48
Post Id


Новичок


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


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




Нужно убедится что подключение к БД и инклюд файла проходят нормально. Замените include на require, а к
CODE (htmlphp):
скопировать код в буфер обмена
  1. $link = mysql_connect ("localhost","root","");
добавьте or die ("Не могу подключиться к серверу БД").
CODE (htmlphp):
скопировать код в буфер обмена
  1. $link = mysql_connect ("localhost","root","") or die ("Не могу подключиться к серверу БД");

Также можно добавить к
or die(mysql_error)

(Добавление)
Говорит что в $result не ресурс. Проверь var_dump'ом, что там.

(Отредактировано автором: 11 Января, 2013 - 12:41:54)

 
 Top
b0d
Отправлено: 11 Января, 2013 - 12:38:07
Post Id


Новичок


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


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




все осталось на своих местах. Нахмурился
 
 Top
vvn
Отправлено: 11 Января, 2013 - 12:39:22
Post Id


Новичок


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


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




Что говорит var_dump($result) ?
(Добавление)
А еще к квери добавь
CODE (htmlphp):
скопировать код в буфер обмена
  1. $result=mysql_query("Select body FROM pages WHERE page='page1.php'",$link) or die(mysql_error());
 
 Top
b0d
Отправлено: 11 Января, 2013 - 12:42:24
Post Id


Новичок


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


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




bool(false)
 
 Top
vvn
Отправлено: 11 Января, 2013 - 12:44:34
Post Id


Новичок


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


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




Вот, уже что-то. Добавляй к квери - or die(mysql_error()).

Ps: Ничего, что я перешел на ты?
 
 Top
Мелкий Супермодератор
Отправлено: 11 Января, 2013 - 12:46:00
Post Id



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


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


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




vvn пишет:
Что говорит var_dump($result) ?

false там, разумеется.
b0d пишет:
mysql_fetch_array() expects parameter 1 to be resource, boolean given in:

mysql_query буль возвращает только в одном случае - ошибка запроса.

vvn пишет:
Нужно убедится что подключение к БД и инклюд файла проходят нормально.

Варнинги включены, а раз тихо, значит проходит нормально.
Если бы не было коннекта к базе, был бы другой, но соответствующий варнинг

vvn пишет:
or die(mysql_error)

mysql_error - функция, а не константа. Как функцию вызывать и надо.

Сделайте после mysql_query

Гадать можно долго, пусть сама база говорит, что не понравилось.


-----
PostgreSQL DBA
 
 Top
b0d
Отправлено: 11 Января, 2013 - 12:47:41
Post Id


Новичок


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


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




Unknown column 'page' in 'where clause'
(Добавление)
vvn пишет:
Вот, уже что-то. Добавляй к квери - or die(mysql_error()).

Ps: Ничего, что я перешел на ты?

не страшно Улыбка
 
 Top
vvn
Отправлено: 11 Января, 2013 - 12:49:51
Post Id


Новичок


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


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




b0d пишет:
Unknown column 'page' in 'where clause'

Ошибка в запросе к БД. Смотри таблицы и сам запрос. Поиграйся с запросом через консоль.
(Добавление)
Если есть желание, запости сюда структуру таблиц поищем вместе.
 
 Top
b0d
Отправлено: 11 Января, 2013 - 12:56:24
Post Id


Новичок


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


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




Простите, а не может быть ошибки в том, что я не указываю какую именно статью хочу вывести, из всех?
 
 Top
vvn
Отправлено: 11 Января, 2013 - 13:01:56
Post Id


Новичок


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


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




CODE (htmlphp):
скопировать код в буфер обмена
  1.  $result=mysql_query("Select body FROM pages WHERE page='page1.php'",$link);

Точно! Я конечно не силён в sql но наверно нужно так
CODE (htmlphp):
скопировать код в буфер обмена
  1.  $result=mysql_query("Select body FROM pages WHERE page LIKE 'page1.php'",$link);

(Отредактировано автором: 11 Января, 2013 - 13:03:00)

 
 Top
Страниц (2): [1] 2 »
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB