आपकी कुछ समस्याएं हैं:
- अनुक्रमणिका से
$row
उद्धरणों में संलग्न करने की आवश्यकता है उदा।$row['name']
अन्यथा आपको बहुत सी "अपरिभाषित स्थिरांक" चेतावनियां मिलेंगी; $row['Jan']
मासिक डेटा पुनर्प्राप्त करने का सही तरीका है, आपको इसे हर दूसरे महीने में दोहराने की आवश्यकता है;$avgGrade
बदलें$row['AVG']
. के साथ- मुझे यकीन नहीं है कि आप क्या हासिल करने की कोशिश कर रहे हैं
<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");