我有两个表,map1
并且,列和map2
之间有多种可能的组合。map1.id1
map2.id2
我尝试了以下查询:
SELECT map1.id1, map2.id2, MIN(ST_HausdorffDistance(map1.g1, map2.g2)),map2.g2
FROM map1, map2
WHERE ST_HausdorffDistance(map1.g1, map2.g2) < 2
GROUP BY map1.id1,map2.g2,map2.id2, ST_HausdorffDistance(map1.g1, map2.g2)
ORDER BY map1.id1,map2.id2, ST_HausdorffDistance(map1.g1, map2.g2)
电流输出
多行id1
:
id1 id2 min g2
---- ---- ---------------- ----------------------------------------------------------------------------------------------------------------------------
6116 338 1.8122154049353 "0102000020E610000002000000590E3EDEF5AB23409255B6B4BF1B4A4031197DBBDBAB23404AF663EEB51B4A40"
6116 645 1.82162999509807 "0102000020E61000000300000057900B73277D2340A1675831011E4A4094C55801197D23406A204C40021E4A40B0CFF7AE9C7C234079AAE8B4131E4A40"
6116 674 1.82397666934862 "0102000020E610000002000000AC0E6F8C53B723405B80118F1F1E4A404EFF48C78BB723406C9159620A1E4A40"
65 695 1.22999509807 "01456020E61000000300000057900B73277D2340A1675831011E4A4094C55801197D23406A204C40021E4A40B0CFF7AE9C7C234079AAE8B4131E4A40"
65 689 1.556666934862 "0202000020E610000002000000AC0E6F8C53B723405B80118F1F1E4A404EFF48C78BB723406C9159620A1E4A40"
-- many more ...
期望的输出
我只想为每个选择第 1 行或第 2 行id1
- 由最小Hausdorff 距离定义:
id1 id2 min g2
---- ---- ---------------- --------------------------------------------------------------------------------------------------------------------------
6116 338 1.8122154049353 "0102000020E610000002000000590E3EDEF5AB23409255B6B4BF1B4A4031197DBBDBAB23404AF663EEB51B4A40"
6116 645 1.82162999509807 "0102000020E61000000300000057900B73277D2340A1675831011E4A4094C55801197D23406A204C40021E4A40B0CFF7AE9C7C234079AAE8B4131E4A40"
65 695 1.22999509807 "01456020E61000000300000057900B73277D2340A1675831011E4A4094C55801197D23406A204C40021E4A40B0CFF7AE9C7C234079AAE8B4131E4A40"
65 689 1.556666934862 "0202000020E610000002000000AC0E6F8C53B723405B80118F1F1E4A404EFF48C78BB723406C9159620A1E4A40"
gis.SE 上的相关答案以说明术语“Hausdorff 距离”: