【发布时间】:2013-01-04 08:09:39
【问题描述】:
我有两张表,比如 A 和 B,其中包含两列城市信息:纬度和经度。 A 包含 100,000 条记录,B 包含 1,000,000 条记录。我的目标是找到距离 A 1 公里以内的 B 行(对于 A 中的每一行)。我该如何有效地做到这一点?我的目标是不到 30 分钟。
以下查询需要很长时间(我相信这是 100,000 * 1,000,000 = 1000 亿行比较的叉积的结果!):
select *
from A
inner join B
on is_nearby(A.latitude, A.longitude, B.latitude, B.longitude)
is_nearby() 只是一个简单的函数,用于查找经纬度之间的差异。
我对A的一行做了测试,每行大约需要5秒。根据我的计算,查询需要几个星期才能完成执行,这是不可接受的。
【问题讨论】:
-
我曾考虑过使用 PostGIS,但我不确定它是否会显着提高性能。有人有更好的主意吗?
-
你看右边相关问题(如this one)的答案了吗?
-
我尝试了 PostGIS 解决方案,它就像一个魅力。谢谢!
标签: postgresql join query-optimization postgis