如何按日期间隔选择唯一身份访问者?

时间:2011-06-30 02:04:05

标签: php mysql sql group-by

我发现了一些与我正在寻找的相关的查询字符串,但没有做到这一点。基本上,我有一个图表,需要显示每个时间间隔(小时,天,月或年)的唯一访问者。因此,图表类似于Google Analytics或this Analytics Graph。该表具有访问者ID列和时间戳列(在函数00:00:00中)。我需要能够选择每个区间的唯一或总访问者(例如,5日的32位访问者,6位的30位访问者等)。

我想我的问题是,无论如何只需查询就可以有效地做到这一点吗?或者我是否需要使用PHP来获取所有数据(问题是我必须对图上的每个点进行查询,效率不高)?

3 个答案:

答案 0 :(得分:1)

您需要汇总数据。试试这个问题:

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

以下是填充月度数据的方法(警告:未经测试!):

<?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()从您的数据中获取日期和
  • COUNT()来计算该特定日期的总数据。
  • 和GROUP BY根据您选择的字段对数据进行分组。

答案 1 :(得分:0)

基本上,您可以将DATETIME / TIMESTAMP分别转换为日期和时间,然后使用GROUP BY来获得所需的结果。

MySQL/SQL: Group by date only on a Datetime column

答案 2 :(得分:0)

如果某天没有访问者,

GROUP BY不会返回0值。这将导致时间连续性的漏洞。有两种方法:

1)像其他人一样说组然后找到漏洞

2)创建包含字段“date”,“count”等的聚合表,并每天用cron插入数据。