Vous devrez agréger vos données. Essayez cette requête :
SELECT DATE(data_timestamp), COUNT(visitor_id)
FROM analytics_table
WHERE DATE(data_timestamp) BETWEEN '2011-05-01' AND '2011-05-31'
GROUP BY 1
Voici comment remplir vos données mensuelles (ATTENTION :NON TESTÉ ! ):
<?php
$sql = "SELECT DATE(data_timestamp), COUNT(visitor_id)
FROM analytics_table
WHERE DATE(data_timestamp) BETWEEN '2011-05-01' AND '2011-05-31'
GROUP BY 1";
$rs = mysql_query($rs);
$date1 = $datex = '2011-05-01';
$date2 = '2011-05-31';
$arrayData = $tmpArray = array();
while( $r = mysql_fetch_array($rs) )
{
$tmpArray[$r['date']] = $r['count'];
}
while( $datex <= $date2)
{
if( isset($tmpArray[$datex]) )
{
$arrayData[$datex] = $tmpArray[$datex];
}
else
{
$arrayData[$datex] = 0;
}
list( $y, $m, $d) = explode('-', $datex);
$datex = date('Y-m-d', mktime(0, 0, 0, $m, $d, $y));
}
?>
cette requête utilise :
- DATE() pour obtenir la date de vos données et
- COUNT() pour compter le total des données à partir de cette date particulière.
- et GROUP BY pour regrouper vos données en fonction du champ que vous sélectionnez.