首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何选择每个日期间隔的唯一访客?

如何选择每个日期间隔的唯一访客?
EN

Stack Overflow用户
提问于 2011-06-30 10:04:05
回答 3查看 2.6K关注 0票数 1

我已经找到了一些与我要查找的内容相关的查询字符串,但没有一个能做到这一点。基本上,我有一个图表,需要显示每个时间间隔(小时,日,月,或年)的唯一访问者。因此,这是一个类似于谷歌分析或this Analytics Graph的图表。该表有一个访问者ID列和一个时间戳列(样式为0000-00-00 00:00:00)。我需要能够选择每个时间间隔的唯一或总访问者(例如,5号32人,6号30人,等等)。

我想我的问题是,有没有什么方法可以只用一个查询就能有效地做到这一点?或者我需要使用PHP来获取所有数据(这样做的问题是我必须对图形上的每个点进行一次查询,效率不高)?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-06-30 10:15:08

您需要聚合您的数据。尝试此查询:

代码语言:javascript
运行
复制
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

以下是如何填充每月数据(警告:未测试!):

代码语言:javascript
运行
复制
<?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));
}


?>

此查询使用:

()从您的数据中获取日期,

  • count ()计算该特定日期的总数据。
  • 和GROUP BY根据您选择的字段对数据进行分组。
票数 1
EN

Stack Overflow用户

发布于 2011-06-30 10:14:31

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

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

票数 0
EN

Stack Overflow用户

发布于 2011-06-30 12:43:41

如果某天没有访问者,GROUP BY不会返回0值。这将导致时间连续性的漏洞。有两种方法:

1)像别人说的那样分组,然后找洞

2)创建包含date、count等字段的聚合表,并通过cron每天在其中插入数据。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6529245

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档