繁体   English   中英

用MySQL计算唯一IP地址

[英]Counting unique IP addresses with MySQL

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

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

我唯一的问题是,要对由该IP地址得出的结果进行计数,MySQL中是否有一种方法可以仅对每个IP地址进行计数,对其进行唯一计数,而不是对它们进行分组然后对其进行计数。

干杯。

您可以使用COUNT(DISTINCT ...)来计算唯一IP地址的数量。 我不确定您要问的是什么,但是您可以尝试一下,也可以根据自己的需要进行调整:

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

关于什么 :

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

在那里,您将数出distinct IP地址的数量-这应该是您想要的; 并且不再需要group by子句。

以下应该可以解决问题:

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

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

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM