Не могу понять, как получить данные из MySql Query - PullRequest
1 голос
/ 17 апреля 2020

Ранее я задал вопрос о том, как выполнить этот запрос, и получил отличный ответ. К сожалению, он немного сложнее, чем запросы, которые я обычно выполняю, поэтому я не могу понять, как получить результаты и отобразить их на моей веб-странице. Вот ссылка на оригинальный вопрос оригинальный вопрос

     <?php

// Associative array
$result = $db->query("SELECT Name,
       COALESCE(AVG(CASE WHEN mth = 1 THEN PTS END), 0) AS Jan,
       COALESCE(AVG(CASE WHEN mth = 2 THEN PTS END), 0) AS Feb,
       COALESCE(AVG(CASE WHEN mth = 3 THEN PTS END), 0) AS Mar,
       COALESCE(AVG(CASE WHEN mth = 4 THEN PTS END), 0) AS Apr,
       COALESCE(AVG(CASE WHEN mth = 5 THEN PTS END), 0) AS May,
       COALESCE(AVG(CASE WHEN mth = 6 THEN PTS END), 0) AS Jun,
       COALESCE(AVG(CASE WHEN mth = 7 THEN PTS END), 0) AS Jul,
       COALESCE(AVG(CASE WHEN mth = 8 THEN PTS END), 0) AS Aug,
       COALESCE(AVG(CASE WHEN mth = 9 THEN PTS END), 0) AS Sep,
       COALESCE(AVG(CASE WHEN mth = 10 THEN PTS END), 0) AS Oct,
       COALESCE(AVG(CASE WHEN mth = 11 THEN PTS END), 0) AS Nov,
       COALESCE(AVG(CASE WHEN mth = 12 THEN PTS END), 0) AS Dec,
       AVG(PTS) AS AVG
FROM (
  SELECT Name, `Points Pass` AS PTS, MONTH(STR_TO_DATE(`OS Date`, '%a %b %e %H:%i:%s %Y')) AS mth
  FROM data
) d
GROUP BY Name");


while($row = mysqli_fetch_array($result)) {

            ?>

         <tr>
                <td><?php echo $row['Name']; ?></td>
                <td class = "gScore-<?php echo $row['Jan']; ?>"><?php echo $row['Jan']; ?></td>
                <td class = "gScore-<?php echo $row['Feb']; ?>"><?php echo $row['Feb']; ?></td>
                <td class = "gScore-<?php echo $row['Mar']; ?>"><?php echo $row['Mar']; ?></td>
                <td class = "gScore-<?php echo $row['Apr']; ?>"><?php echo $row['Apr']; ?></td>
                <td class = "gScore-<?php echo $row['May']; ?>"><?php echo $row['May']; ?></td>
                <td class = "gScore-<?php echo $row['Jun']; ?>"><?php echo $row['Jun']; ?></td>
                <td class = "gScore-<?php echo $row['Jul']; ?>"><?php echo $row['Jul']; ?></td>
                <td class = "gScore-<?php echo $row['Aug']; ?>"><?php echo $row['Aug']; ?></td>
                <td class = "gScore-<?php echo $row['Sep']; ?>"><?php echo $row['Sep']; ?></td>
                <td class = "gScore-<?php echo $row['Oct']; ?>"><?php echo $row['Oct']; ?></td>
                <td class = "gScore-<?php echo $row['Nov']; ?>"><?php echo $row['Nov']; ?></td>
                <td class = "gScore-<?php echo $row['Dec']; ?>"><?php echo $row['Dec']; ?></td>
                <td><?php echo $row['AVG']; ?></td>
            </tr>
        <?php   


}
if (!$result) { echo $db->error; }

1 Ответ

1 голос
/ 17 апреля 2020

У вас есть несколько проблем:

  1. Индексы $row должны быть заключены в кавычки, например $row['name'] в противном случае вы получите много предупреждений "Неопределенная константа";
  2. $row['Jan'] - это правильный способ получения данных за месяц, вам необходимо повторить их для каждого другого месяца;
  3. заменить $avgGrade на $row['AVG']
  4. I ' я не уверен, чего ты хочешь достичь с помощью
<td class = "gScore-<?php echo $row[Jan]; ?>"></td>

ты действительно хочешь

<td class = "gScore"><?php echo $row[Jan]; ?></td>
вам нужно добавить -- repeat for May to November строки к запросу, т.е.
    $result = $db->query("SELECT name,
       COALESCE(AVG(CASE WHEN mth = 1 THEN PTS END), 0) AS Jan,
       COALESCE(AVG(CASE WHEN mth = 2 THEN PTS END), 0) AS Feb,
       COALESCE(AVG(CASE WHEN mth = 3 THEN PTS END), 0) AS Mar,
       COALESCE(AVG(CASE WHEN mth = 4 THEN PTS END), 0) AS Apr,
       COALESCE(AVG(CASE WHEN mth = 5 THEN PTS END), 0) AS May,
       COALESCE(AVG(CASE WHEN mth = 6 THEN PTS END), 0) AS Jun,
       COALESCE(AVG(CASE WHEN mth = 7 THEN PTS END), 0) AS Jul,
       COALESCE(AVG(CASE WHEN mth = 8 THEN PTS END), 0) AS Aug,
       COALESCE(AVG(CASE WHEN mth = 9 THEN PTS END), 0) AS Sep,
       COALESCE(AVG(CASE WHEN mth = 10 THEN PTS END), 0) AS Oct,
       COALESCE(AVG(CASE WHEN mth = 11 THEN PTS END), 0) AS Nov,
       COALESCE(AVG(CASE WHEN mth = 12 THEN PTS END), 0) AS `Dec`,
       AVG(PTS) AS AVG
   FROM (
   SELECT name, PTS AS PTS, MONTH(STR_TO_DATE(DATE, '%a %b %e %H:%i:%s %Y')) AS mth
   FROM data
    ) d
    GROUP BY name");
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...