我有一个数据库,里面有订单,需要生成一个PNG图来显示每月下的订单总数。我可以从普通数组中实现这一点,但我似乎无法从数据库查询中实现它。
我认为需要更改的代码是循环的第三个和第四个,因为这是我认为生成月份名称和条形图的代码。
以下是通过数组工作的代码,其中我需要使用的SQL查询在$values数组下面声明:
<?php
require_once(DATABASE CONNECTOR REMOVED);
//Set the values
$values=array(
"Jan" => 1100,
"Feb" => 1300,
"Mar" => 2150,
"Apr" => 810,
"May" => 3100,
"Jun" => 1100,
"Jul" => 1900,
"Aug" => 1750,
"Sep" => 3900,
"Oct" => 2860,
"Nov" => 1500,
"Dec" => 1960
);
$query = mysql_query("SELECT SUM(order_total) AS total, MONTHNAME(FROM_UNIXTIME(order_date)) AS month FROM orders GROUP BY YEAR (order_date), MONTH(order_date)") or die ('Error: '.mysql_error());
$img_width=600;
$img_height=400;
$margins=35;
$graph_width=$img_width - $margins * 2;
$graph_height=$img_height - $margins * 2;
$img=imagecreatetruecolor($img_width,$img_height);
$bar_width=20;
$total_bars=count($values);
$gap= ($graph_width- $total_bars * $bar_width ) / ($total_bars +1);
$bar_color=imagecolorallocate($img,70,85,96);
$background_color=imagecolorallocate($img,255,255,255);
$border_color=imagecolorallocate($img,200,200,200);
$line_color=imagecolorallocate($img,70,85,96);
imagefilledrectangle($img,1,1,$img_width-2,$img_height-2,$border_color);
imagefilledrectangle($img,$margins,$margins,$img_width-1-$margins,$img_height-1-$margins,$background_color);
$max_value=max($values);
$ratio= $graph_height/$max_value;
$horizontal_lines=20;
$horizontal_gap=$graph_height/$horizontal_lines;
for($i=1;$i<=$horizontal_lines;$i++){
$y=$img_height - $margins - $horizontal_gap * $i ;
imageline($img,$margins,$y,$img_width-$margins,$y,$line_color);
$v='£'.intval($horizontal_gap * $i /$ratio);
imagettftext($img, 8, 0, 2 ,$y+5, $bar_color, 'includes/trebuc.ttf', $v);
}
for($i=1;$i<=$horizontal_lines;$i++){
$y=$img_height - $margins - $horizontal_gap * $i ;
imageline($img,$margins,$y,$img_width-$margins,$y,$line_color);
$v='£'.intval($horizontal_gap * $i /$ratio);
imagettftext($img, 8, 0, 2 ,$y+5, $bar_color, 'includes/trebuc.ttf', $v);
}
for($i=0;$i< $total_bars; $i++){
list($key,$value)=each($values);
$x1= $margins + $gap + $i * ($gap+$bar_width) ;
$x2= $x1 + $bar_width;
$y1=$margins +$graph_height- intval($value * $ratio) ;
$y2=$img_height-$margins;
imagefilledrectangle($img,$x1,$y1,$x2,$y2,$bar_color);
imagettftext($img, 10, 0, $x1,$img_height - 14, $bar_color, 'includes/trebuc.ttf', $key);
}
for($i=0;$i< $total_bars; $i++){
list($key,$value)=each($values);
$x1= $margins + $gap + $i * ($gap+$bar_width) ;
$x2= $x1 + $bar_width;
$y1=$margins +$graph_height- intval($value * $ratio) ;
$y2=$img_height-$margins;
imagefilledrectangle($img,$x1,$y1,$x2,$y2,$bar_color);
imagettftext($img, 10, 0, $x1,$img_height - 14, $bar_color, 'includes/trebuc.ttf', $key);
}
header("Content-type:image/png");
imagepng($img);
?>
编辑
我知道这不仅仅局限于过去的12个月,我的目标是在根据数据库
您必须获取结果并填充$values
数组:
mysql_query()
:之后
$values = array();
while ($row = mysql_fetch($query) {
$values[substr($row['month'], 0, 3)] = $row['total'];
}