[英]how to display mysql results into different columns based off of values
好的,我在學習如何從查詢中獲取值以根據查詢中的值顯示在不同列中的過程上確實花費了3天的時間。 這是我想要的樣子...
Name 0-30 30-60 60-90 90+
john $50
june $0.00
joe $100
fred $500
到目前為止,我可以獲得上面的名稱和貨幣值的列表,但是我只知道如何如下顯示它們...
Name 0-30 30-60 60-90 90+
john $50 $50 $50 $50
june $0.00 $0.00 $0.00 $0.00
joe $100 $100 $100 $100
fred $500 $500 $500 $500
我很簡單地在每列中打印變量。 任何幫助是極大的贊賞。
echo "<TABLE WIDTH='100%' BORDER='0' CELLSPACING='0' CELLPADDING='5'>
<TR>
<TD WIDTH='5%'><B>Job</B><BR></TD>
<TD WIDTH='30%'><B>Name</B><BR></TD>
<TD WIDTH='12%'><B>0-30 Days</B><BR></TD>
<TD WIDTH='12%'><B>30-60 Days</B><BR></TD>
<TD WIDTH='12%'><B>60-90 Days</B><BR></TD>
<TD WIDTH='12%'><B>90+ Days</B><BR></TD>
<TD WIDTH='15%'><B>Total Amount</B><BR></TD>
</TR><TR>";
此處的SQL查詢... sqlfiddle。 http://sqlfiddle.com/#!2/e5d9c/1/0
echo "<TD WIDTH='5%'>$primary_key</TD>
<TD WIDTH='30%'>$a_name</TD>
<TD WIDTH='12%'>$total / $timeperiod</TD>
<TD WIDTH='12%'>$total / $timeperiod</TD>
<TD WIDTH='12%'>$total / $timeperiod</TD>
<TD WIDTH='12%'>$total / $timeperiod</TD>
<TD WIDTH='15%'>$total / $timeperiod</TD>
</TR>";
我知道以上內容是錯誤的,但是我不確定上面要顯示的內容是我想要的例子嗎?
只需在列中的回顯之前添加一個條件即可。 應該看起來像:
`if($ res ['name']> = 0且$ res ['name'] <30)回顯$ res ['data'];
if($ res ['name']> = 30並且$ res ['name'] <60)回顯$ res ['data'];
if($ res ['name']> = 60並且$ res ['name'] <90)echo $ res ['data'];`
....
// $ res ['name']-> john / june ... // $ res ['data']-> $ 50 / $ 500 ...
我認為這是最簡單的方法。
下面的代碼片段將滿足您的需要。
<?php
$query = "SELECT amount FROM mytable";
$res = mysql_query($query);
while($data = mysql_fetch_row($res))
{
echo "<tr>";
if($data[0] < 30)
{
echo "<td colspan='4' align='left'>".$data[0]."</td>";
}
else
{
echo "<td> </td>";
if($data[0] > 30 && $data[0] < 60)
echo "<td colspan='3' align='left'>".$data[0]."</td>";
else
{
echo "<td> </td>";
if($data[0] > 60 && $data[0] < 90)
echo "<td colspan='2' align='left'>".$data[0]."</td>";
else
{
echo "<td> </td>";
if($data[0] > 90)
echo "<td align='left'>".$data[0]."</td>";
}
}
}
echo "</tr>";
}
?>
SELECT
Name,
c0_30, c30_60, c60_90, c90
FROM (
SELECT
Name,
SUM(IF(val BETWEEN 0 AND 30, val, NULL)) As 'c0_30',
SUM(IF(val BETWEEN 31 AND 60, val, NULL)) As 'c30_60',
SUM(IF(val BETWEEN 61 AND 90, val, NULL)) As 'c60_90',
SUM(IF(val > 90, val, NULL)) As 'c90'
FROM talName
GROUP BY Name WITH ROLLUP
) AS sums;
該查詢將輸出一個人的val
col的總價值,並根據其總價值將其分類到合適的列。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.