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]   

> Без описания
inkor
Отправлено: 22 Октября, 2010 - 12:28:51
Post Id


Новичок


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


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




Здравствуйте!
работаю на денвере.
ситуация такая - по запросу из базы должны выводиться названия 5 последних статей (в базе их штук 100) в цикле (цикл сделаю сам), но проблема в выборке.

запрос выглядит так

CODE (htmlphp):
скопировать код в буфер обмена
  1.  
  2. $result = mysql_query ("SELECT title FROM articles ORDER BY (id) DESC LIMIT 5",$db);
  3. $myrow = mysql_fetch_array ($result);
  4.  
  5.  print_r ($myrow);
  6.  


т.е. print_r должен выводить в понятном человеку виде все что попадает в $myrow, но по запросу туда попадает только одно значение.

Выводит в браузер вот это
Array ( [0] => Сердцем — не стареть [title] => Сердцем — не стареть )

нутром чую что косяк идиотский, ведь запрос должен выводить 5 значений, что я сделал ни так?
 
 Top
CenapaTop
Отправлено: 22 Октября, 2010 - 13:29:13
Post Id



Частый гость


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


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




Цикл.

(Отредактировано автором: 22 Октября, 2010 - 14:44:21)

 
 Top
inkor
Отправлено: 22 Октября, 2010 - 14:37:10
Post Id


Новичок


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


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




в $myrow я получаю заголовки из базы , а потом вывожу их в цикле.
print_r ($myrow); просто показывает, что у меня попало в $myrow.

ведь в цикле я буду из массива доставать значения, я уже подобное делал раньше и все работало
 
 Top
CenapaTop
Отправлено: 22 Октября, 2010 - 14:44:07
Post Id



Частый гость


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


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




PHP:
скопировать код в буфер обмена
  1. while ($myrow = mysql_fetch_array ($result)) {
  2.         print_r ($myrow);  
  3.     }
 
 Top
inkor
Отправлено: 22 Октября, 2010 - 17:50:01
Post Id


Новичок


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


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




дело в том что в цикле тоже выводит только первое значение , ведь данные для цикла берутся 1 раз из базы и суются в массив myrow, а из него в цикле выводятся по очереди
 
 Top
Мелкий Супермодератор
Отправлено: 22 Октября, 2010 - 17:54:43
Post Id



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


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


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




inkor пишет:
ведь данные для цикла берутся 1 раз из базы и суются в массив myrow, а из него в цикле выводятся по очереди

Нет, данные берутся и помещаются в ресурс. А ресурс обходится в цикле функциями mysql_fetch_*, за каждый вызов возвращают массив текущей строки по внутреннему для ресурса счётчику и увеличивают этот счётчик.


-----
PostgreSQL DBA
 
 Top
OrmaJever
Отправлено: 22 Октября, 2010 - 17:55:43
Post Id



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


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


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




лимит нужно писать двумя цифрами. С какой начинается борка и сколько выбирать полей.
CODE (SQL):
скопировать код в буфер обмена
  1. "SELECT title FROM articles ORDER BY (id) DESC LIMIT 0,5"

попробуй так.


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
CenapaTop
Отправлено: 22 Октября, 2010 - 18:13:18
Post Id



Частый гость


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


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




OrmaJever пишет:
лимит нужно писать двумя цифрами

или одна цифра или две.
 
 Top
inkor
Отправлено: 22 Октября, 2010 - 20:55:57
Post Id


Новичок


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


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




Мелкий пишет:
Нет, данные берутся и помещаются в ресурс. А ресурс обходится в цикле функциями mysql_fetch_*, за каждый вызов возвращают массив текущей строки по внутреннему для ресурса счётчику и увеличивают этот счётчик.


ваша правда!
Совсем туплю в последнее время, надо с учебой завязывать Радость
все работает! всем спасибо!!
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« SQL и Архитектура БД »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB