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
Форумы портала PHP.SU :: Версия для печати :: функция выборки из базы
Форумы портала PHP.SU » » Вопросы новичков » функция выборки из базы

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

1. foozzi - 25 Августа, 2012 - 23:22:02 - перейти к сообщению
Есть функция которая возвращает масив с данными из базы:
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 не определенная переменная, хотя функция возвращает масив, в чем дело?
2. Green - 25 Августа, 2012 - 23:30:23 - перейти к сообщению
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.  
3. Muxa - 25 Августа, 2012 - 23:38:08 - перейти к сообщению
foozzi пишет:
function &view() {
а зачем жесткую привязку функции делать?
4. foozzi - 26 Августа, 2012 - 04:05:39 - перейти к сообщению
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 запись из базы
5. KingStar - 26 Августа, 2012 - 09:55:09 - перейти к сообщению
foozzi пишет:
PHP:
скопировать код в буфер обмена
  1. $query = mysql_query("SELECT * FROM screen WHERE valid = 1 ORDER BY id DESC LIMIT 10");


а в базе точно несколько записей, которые соответствуют условию valid = 1 ???
6. Green - 26 Августа, 2012 - 13:09:28 - перейти к сообщению
foozzi пишет:
а отображается при выводе только 1 запись из базы

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

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

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

вывожу <?=$data['name']?>
8. KingStar - 26 Августа, 2012 - 23:17:23 - перейти к сообщению
не так это делается, у тебя проделывается двойная работа, вначале в цикле функции, а затем в цикле вывода, зачем такие грабли???
9. foozzi - 26 Августа, 2012 - 23:34:13 - перейти к сообщению
KingStar пишет:
не так это делается, у тебя проделывается двойная работа, вначале в цикле функции, а затем в цикле вывода, зачем такие грабли???

в том то и дело, что не знаю как правильно
10. KingStar - 26 Августа, 2012 - 23:36:27 - перейти к сообщению
вот здесь похожее обсуждал сегодня
http://php.su/forum/topic.php?fo...1&topic=6908

 

Powered by ExBB FM 1.0 RC1