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. Грачи прилетели - 19 Мая, 2015 - 08:57:37 - перейти к сообщению
Добрый день!

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

$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` но в ступоре не понимаю, что с этим делать, т.к. сумма при таком запросе не считается

толкните, пожалуйста
2. Sail - 19 Мая, 2015 - 09:02:01 - перейти к сообщению
Грачи прилетели, раз уж нужны все `name`, то почему-бы не считать сумму в цикле обработки?
Ну и в запросе добавить order by `fio`, `name`, для упрощения понимания, что перешли к следующей группе `fio`...
3. Грачи прилетели - 19 Мая, 2015 - 10:26:09 - перейти к сообщению
добавил
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?
4. Sail - 19 Мая, 2015 - 11:17:29 - перейти к сообщению
Грачи прилетели пишет:
при таком выводе убираю повторы fio, но как мне в цикле просуммировать значение zagruz?

Например, так:
Спойлер (Отобразить)

 

Powered by ExBB FM 1.0 RC1