あなたのデータを集計する必要があります。この文字列で検索してください:
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
はここ(WARNING!:未テスト):あなたはあなたの月次データを取り込む方法を説明します
<?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));
}
?>
このクエリの使用は:
- DATE()を取得しますあなたのデータの日付と
- その特定の日付からの合計データを数えます。
- とGROUP BYを使用して、選択したフィールドに基づいてデータをグループ化します。
必要なものは次のとおりです: 'GROUP BY'、' COUNT() '、' DATE() ' – zerkms
この質問の重複によく似ています:http://stackoverflow.com/questions/366603/mysql-sql -group-date-on-a-datetime-column – jefflunt