关于计数的SQL问题

发布于 2024-08-02 22:10:19 字数 461 浏览 7 评论 0原文

我想进行查询,以便只能获取至少有 50 个地点的位置。

我有一个位置表:

Id, City, Country
1, Austin, USA
2, Paris, France

以及一个通过 Location_id 连接到位置的地点表

Id, Name, Details, Location_id
1, The Zoo, blah, 2
2, Big Park, blah, 2

我可以像这样加入它们:

SELECTplaces.name,places.id,locations.country,locations.city 来自地点 内连接位置 ON place.location_id =locations.id

by 如何才能只获取至少有 50 个地点的城市的结果,并按最大数量对它们进行排序?

谢谢!

I want to make a query so that I can grab only Locations that have at least 50 Places.

I have a table of Locations:

Id, City, Country
1, Austin, USA
2, Paris, France

And a table of Places connected to Locations by Location_id

Id, Name, Details, Location_id
1, The Zoo, blah, 2
2, Big Park, blah, 2

I can join them like so:

SELECT places.name, places.id, locations.country, locations.city
FROM places
INNER JOIN locations
ON places.location_id = locations.id

by how can I only get the results of cities that have at least 50 places and order them by the largest amount?

Thanks!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

梦与时光遇 2024-08-09 22:10:19

使用带有 HAVING 子句的 GROUP BY 子句。

SELECT locations.country, locations.city, COUNT(*)
FROM places
     INNER JOIN locations ON places.location_id = locations.id
GROUP BY locations.country, locations.city
HAVING COUNT(*) >= 50

Use a GROUP BY with a HAVING clause.

SELECT locations.country, locations.city, COUNT(*)
FROM places
     INNER JOIN locations ON places.location_id = locations.id
GROUP BY locations.country, locations.city
HAVING COUNT(*) >= 50
愚人国度 2024-08-09 22:10:19

好的,我已经看到上面的答案差不多了,但有一些错误,所以只发布正确的版本:

SELECT locations.country, locations.city, COUNT(*) as count_of_places
FROM places
     INNER JOIN locations ON places.location_id = locations.id
GROUP BY locations.country, locations.city
HAVING COUNT(*) >= 50
ORDER BY count_of_places;

OK I've seen that the above answers are almost there but have some mistakes, so just posting the correct version:

SELECT locations.country, locations.city, COUNT(*) as count_of_places
FROM places
     INNER JOIN locations ON places.location_id = locations.id
GROUP BY locations.country, locations.city
HAVING COUNT(*) >= 50
ORDER BY count_of_places;
落花随流水 2024-08-09 22:10:19

您可以使用 having 子句通过聚合列的值来限制这些行。另外,MySQL 允许您使用惰性group by,因此您绝对可以利用这一点:

select
    l.country,
    l.city,
    p.name,
    p.details,
    count(*) as number_of_places
from
    locations l
    inner join places p on
        l.id = p.location_id
group by
    l.id
having
    count(*) >= 50
order by
    number_of_places,
    l.country,
    l.city,
    p.name

You can use the having clause to limit these rows by the value of an aggregate column. Also, MySQL allows you to use lazy group bys, so you can absolutely take advantage of this:

select
    l.country,
    l.city,
    p.name,
    p.details,
    count(*) as number_of_places
from
    locations l
    inner join places p on
        l.id = p.location_id
group by
    l.id
having
    count(*) >= 50
order by
    number_of_places,
    l.country,
    l.city,
    p.name
只为守护你 2024-08-09 22:10:19

性能有些不佳,但应该可以:

选择places.name、places.id、sq.country、sq.city、sq.counter
FROM(SELECT Locations.id、国家、城市、count(*) 作为计数器 FROM Locations
加入地点 ON (Locations.Id=Places.Location_id)
GROUP BYlocations.id HAVING count(*) >= 50) AS sq
加入地点 ON (sq.id=Places.Location_id)
ORDER BY 计数器 DESC`

PS 确切的语法可能会因数据库而异,我不确定这是否与 mysql 兼容。

Somewhat unperformant, but should work:

SELECT places.name, places.id, sq.country, sq.city, sq.counter
FROM (SELECT Locations.id, country,city, count(*) as counter FROM Locations
JOIN Places ON (Locations.Id=Places.Location_id)
GROUP BY locations.id HAVING count(*) >= 50) AS sq
JOIN Places ON (sq.id=Places.Location_id)
ORDER BY counter DESC`

P.S. The exact syntax may vary depending on the database, I'm not sure if this is mysql-compatible as is.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文