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]   

> Без описания
foozzi
Отправлено: 25 Августа, 2012 - 23:22:02
Post Id



Посетитель


Покинул форум
Сообщений всего: 283
Дата рег-ции: Май 2011  
Откуда: rm -rf /


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




Есть функция которая возвращает масив с данными из базы:
PHP:
скопировать код в буфер обмена
  1. function &view() {
  2.   $query = mysql_query("SELECT * FROM screen WHERE valid = 1 ORDER BY id DESC LIMIT 10");
  3.   $arr = array();
  4.   while($view = mysql_fetch_assoc($query)) { $arr[] = $view; }
  5.   return $arr;
  6. }
  7.  

в файле шаблона вызывают функцию, потом пытаюсь вывести данные например $arr['name'] но пишет что $arr не определенная переменная, хотя функция возвращает масив, в чем дело?


-----
90% ошибок находятся в полуметре от монитора...
 
 Top
Green
Отправлено: 25 Августа, 2012 - 23:30:23
Post Id



Частый гость


Покинул форум
Сообщений всего: 214
Дата рег-ции: Апр. 2012  
Откуда: Кисловодск


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




PHP:
скопировать код в буфер обмена
  1.  
  2. $view = view();
  3. echo $view['name'];

PHP:
скопировать код в буфер обмена
  1.  
  2. $views = view();
  3. foreach($views as $view)
  4. {
  5.    echo $view['name'], '<br />';
  6. }
  7.  

(Отредактировано автором: 25 Августа, 2012 - 23:56:19)

 
 Top
Muxa
Отправлено: 25 Августа, 2012 - 23:38:08
Post Id



Частый гость


Покинул форум
Сообщений всего: 247
Дата рег-ции: Март 2012  
Откуда: Россия, Тверь


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




foozzi пишет:
function &view() {
а зачем жесткую привязку функции делать?
 
 Top
foozzi
Отправлено: 26 Августа, 2012 - 04:05:39
Post Id



Посетитель


Покинул форум
Сообщений всего: 283
Дата рег-ции: Май 2011  
Откуда: rm -rf /


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




Green пишет:
PHP:
скопировать код в буфер обмена
  1.  
  2. $view = view();
  3. echo $view['name'];

PHP:
скопировать код в буфер обмена
  1.  
  2. $views = view();
  3. foreach($views as $view)
  4. {
  5.    echo $view['name'], '<br />';
  6. }
  7.  

Notice: Undefined index: name in
ошибочка вышла, не выводит то что в массиве
Цитата:
а зачем жесткую привязку функции делать?

убрал, практиковался
(Добавление)
С этим разобрался, теперь проблема в том, что в самой функции while используется:
PHP:
скопировать код в буфер обмена
  1. function view() {
  2.   $query = mysql_query("SELECT * FROM screen WHERE valid = 1 ORDER BY id DESC LIMIT 10");
  3.   $arr = array();
  4.   while($view = mysql_fetch_assoc($query)) { $arr[] = $view; }
  5.   return $arr;
  6. }

а отображается при выводе только 1 запись из базы


-----
90% ошибок находятся в полуметре от монитора...
 
 Top
KingStar
Отправлено: 26 Августа, 2012 - 09:55:09
Post Id



Участник


Покинул форум
Сообщений всего: 1889
Дата рег-ции: Авг. 2011  
Откуда: Беларусь


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




foozzi пишет:
PHP:
скопировать код в буфер обмена
  1. $query = mysql_query("SELECT * FROM screen WHERE valid = 1 ORDER BY id DESC LIMIT 10");


а в базе точно несколько записей, которые соответствуют условию valid = 1 ???


-----
То что программа работает, не означает что она написана правильно!
 
 Top
Green
Отправлено: 26 Августа, 2012 - 13:09:28
Post Id



Частый гость


Покинул форум
Сообщений всего: 214
Дата рег-ции: Апр. 2012  
Откуда: Кисловодск


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




foozzi пишет:
а отображается при выводе только 1 запись из базы

Ну правильно. Далее через foreach() перебирайте массив, и выводите все записи поочередно. Пример я указал выше. Если Вы так и делаете, то значит в таблице есть только одна запись, которая соответствует условию valid = 1.
 
 Top
foozzi
Отправлено: 26 Августа, 2012 - 22:59:04
Post Id



Посетитель


Покинул форум
Сообщений всего: 283
Дата рег-ции: Май 2011  
Откуда: rm -rf /


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




Green пишет:
foozzi пишет:
а отображается при выводе только 1 запись из базы

Ну правильно. Далее через foreach() перебирайте массив, и выводите все записи поочередно. Пример я указал выше. Если Вы так и делаете, то значит в таблице есть только одна запись, которая соответствует условию valid = 1.

все 3 записи имеют значение valid = 1
делаю так
PHP:
скопировать код в буфер обмена
  1.  $views = view();
  2. foreach($views as $data)

вывожу <?=$data['name']?>


-----
90% ошибок находятся в полуметре от монитора...
 
 Top
KingStar
Отправлено: 26 Августа, 2012 - 23:17:23
Post Id



Участник


Покинул форум
Сообщений всего: 1889
Дата рег-ции: Авг. 2011  
Откуда: Беларусь


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




не так это делается, у тебя проделывается двойная работа, вначале в цикле функции, а затем в цикле вывода, зачем такие грабли???


-----
То что программа работает, не означает что она написана правильно!
 
 Top
foozzi
Отправлено: 26 Августа, 2012 - 23:34:13
Post Id



Посетитель


Покинул форум
Сообщений всего: 283
Дата рег-ции: Май 2011  
Откуда: rm -rf /


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




KingStar пишет:
не так это делается, у тебя проделывается двойная работа, вначале в цикле функции, а затем в цикле вывода, зачем такие грабли???

в том то и дело, что не знаю как правильно


-----
90% ошибок находятся в полуметре от монитора...
 
 Top
KingStar
Отправлено: 26 Августа, 2012 - 23:36:27
Post Id



Участник


Покинул форум
Сообщений всего: 1889
Дата рег-ции: Авг. 2011  
Откуда: Беларусь


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




вот здесь похожее обсуждал сегодня
http://php.su/forum/topic.php?fo...1&topic=6908


-----
То что программа работает, не означает что она написана правильно!
 
 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