使用MySQL计算唯一的IP地址

时间:2011-03-09 22:17:49

标签: php mysql

我正在尝试使用MySQL计算唯一IP地址的总数,这就是我对查询的看法:

SELECT COUNT(`id`) as `count` FROM `pageviews` WHERE `timestamp` BETWEEN '1299675600' AND '1299762000' GROUP BY `client_ip`

我唯一的问题是,它是在计算该IP地址所产生的结果,在MySQL中是否有办法只计算每批IP地址,对它们进行唯一计数,而不是对它们进行分组然后对它们进行计数。 / p>

干杯。

4 个答案:

答案 0 :(得分:4)

您可以使用COUNT(DISTINCT ...)计算唯一IP地址的数量。我不完全确定你的问题是什么,但你可以尝试这个,或者根据你的需要进行调整:

SELECT COUNT(DISTINCT client_ip) as `count`
FROM `pageviews`
WHERE `timestamp` BETWEEN '1299675600' AND '1299762000'

答案 1 :(得分:1)

怎么样:

select count(distinct client_ip) as total_num
from pageviews
where `timestamp` BETWEEN '1299675600' AND '1299762000'

在那里,你将计算distinct个ip地址的数量 - 这应该是你想要的;并且不再需要group by子句。

答案 2 :(得分:0)

以下应该可以解决问题:

SELECT COUNT(DISTINCT `client_ip`) as `count` FROM `pageviews` WHERE `timestamp` BETWEEN '1299675600' AND '1299762000'

不需要按client_ip分组,因为您已经可以使用DISTINCT关键字查询不同的值。

答案 3 :(得分:0)

您可以在COUNT()中使用DISTINCT:

SELECT COUNT(DISTINCT client_ip) as `count` 
FROM `pageviews` WHERE `timestamp` BETWEEN '1299675600' AND '1299762000'