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]   

> Описание: запрос к mysql с форматированием на php
Грачи прилетели
Отправлено: 19 Мая, 2015 - 08:57:37
Post Id



Гость


Покинул форум
Сообщений всего: 81
Дата рег-ции: Май 2015  


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




Добрый день!

Немного впал в ступор, прошу помощи.

$sql="SELECT `name`, SUM(`zagruz`) as zagruz, `fio`
FROM `pt`
GROUP BY `fio`
";
.............

вывожу
echo "<td align='left'> ".$Arr['fio']."</td>
<td> ".$Arr['zagruz']."%</td>
<td> ".$Arr['name']."</td>";

Группирует по fio и считает сумму правильно, мне надо в поле name перечислить все значение через <br /> которые есть без учета группировки, потому что после группировки в поле отображается только одно значение.
пробовал сначала группировать по name потом по fio GROUP BY `name`, `fio` но в ступоре не понимаю, что с этим делать, т.к. сумма при таком запросе не считается

толкните, пожалуйста
 
 Top
Sail
Отправлено: 19 Мая, 2015 - 09:02:01
Post Id



Участник


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


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




Грачи прилетели, раз уж нужны все `name`, то почему-бы не считать сумму в цикле обработки?
Ну и в запросе добавить order by `fio`, `name`, для упрощения понимания, что перешли к следующей группе `fio`...
 
 Top
Грачи прилетели
Отправлено: 19 Мая, 2015 - 10:26:09
Post Id



Гость


Покинул форум
Сообщений всего: 81
Дата рег-ции: Май 2015  


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




добавил
GROUP BY `name`,`fio` ORDER BY `fio` ASC

вывожу так

$rez=mysqli_query($mysqli , $sql);
$c=0;
while($Arr=mysqli_fetch_array($rez)){$c++;

echo "<tr>
<td align='left' > ".($Arr['fio']!=$echo_fio?$Arr['fio']:'')."</td>
<td align='center'> ".$Arr['zagruz']."%</td>
<td align='left'> ".$Arr['name']."<br /></td>
</tr>";

if($echo_fio!=$Arr['fio'])
$echo_fio=$Arr['fio'];
}
при таком выводе убираю повторы fio, но как мне в цикле просуммировать значение zagruz?

(Отредактировано автором: 19 Мая, 2015 - 10:27:59)

 
 Top
Sail
Отправлено: 19 Мая, 2015 - 11:17:29
Post Id



Участник


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


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




Грачи прилетели пишет:
при таком выводе убираю повторы fio, но как мне в цикле просуммировать значение zagruz?

Например, так:
Спойлер (Отобразить)
 
 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