我正在尝试使用MySQL计算唯一IP地址的总数,这就是我对查询的看法:
SELECT COUNT(`id`) as `count` FROM `pageviews` WHERE `timestamp` BETWEEN '1299675600' AND '1299762000' GROUP BY `client_ip`
我唯一的问题是,它是在计算该IP地址所产生的结果,在MySQL中是否有办法只计算每批IP地址,对它们进行唯一计数,而不是对它们进行分组然后对它们进行计数。 / p>
干杯。
答案 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'