如何显示额外的列而不是聚合函数或不在 group by 语句中
我正在使用 postgis 来计算每个“a”与其相应的“b”类型点之间的距离。
到目前为止,我已经设法用这个查询来做到这一点:
SELECT a.name, min(ST_Distance(a.the_geom, b.the_geom)) as distance
FROM a, b
GROUP BY a.name;
这是有效的,但是它只列出了 a 类型点的名称以及到它最近的 b 类型点的距离,它没有列出最近的 b 类型点的名称每个都是我想要的类型点。
我通常会通过连接两个表来做到这一点,但它们不相关并且不共享键,所以我不知道如何连接它们。
I am using postgis to calculate the distance between every 'a' and its corresponding 'b' type point.
So far I have managed to do this with this query:
SELECT a.name, min(ST_Distance(a.the_geom, b.the_geom)) as distance
FROM a, b
GROUP BY a.name;
This works, it however only lists the name of the a type point and the distance to its closest b type point, it doesn't list the name of the closest b type point to each a type point as I'd like it to do.
I would usually do this by joining both tables but they are unrelated and share no keys so I wouldn't know how to join them.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
暴力方法(假设PostGIS支持WITH子句,并假设我的WITH子句语法正确 - 两个未经检查的假设):
这会生成名称列表(
a_name
和b_name) 加上使用笛卡尔积的相应距离(这是您的原始查询在 GROUP BY 启动之前执行的操作)。然后,它选择两个名称以及该表与通过
a_name
分组并在a_name
上连接的同一表的连接距离以及最小距离。显然,如果不支持WITH,您可以将WITH 子句写出两次,并希望您的优化器是好的。
The brute force approach (assuming that PostGIS supports WITH clauses, and assuming I have the syntax of WITH clauses correct - both unchecked assumptions):
This generates the list of names (
a_name
andb_name
) plus the corresponding distance using a Cartesian product (which is what your original query does before the GROUP BY kicks in). It then selects the two names and the distance from the join of that table with the same table grouped over thea_name
and joined on thea_name
and the minimum distance.Clearly, if WITH is not supported, you can write the WITH clause out twice and hope your optimizer is good.