我有一个名为place
的表:
id | name | coordinates (longitude, latitude)
1 | London | -0.12574, 51.50853
2 | Manchester | -2.25, 53.41667
3 | Glasgow | -4.25, 55.86667
coordinates
列属于点数据类型。我使用以下命令将这些点插入到了place
表中:
st_geomfromtext('point($longitude $latitude)', 4326)
注意,我已经使用了SRID。
对于任何坐标,我想找到最近的地方(按升序排序)。目前我想到的解决方案(通过阅读MySQL文档)如下:
select
*,
st_distance_sphere(`place`.`coordinates`, st_geomfromtext('Point($longitude $latitude)', 4326)) as distance
from place
order by distance asc;
在这里和其他地方查看了无数类似的问题后,很明显这是一种较少人知道(也是较新的方法),因此没有太多相关内容,这就是我寻求澄清的原因。
我的问题如下:
- 这是最好的解决方案/我是否做得正确?
- 这种方法会使用我在
coordinates
列上拥有的空间索引吗? - 使用st_distance_sphere时,我需要指定地球半径以获得准确的结果吗? (编辑:不需要,它默认使用地球半径)
编辑,下面是这些答案:
explain select ...;
返回:
id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra
1 | SIMPLE | place | NULL | ALL | NULL | NULL | NULL | NULL | 115687 | 100.00 | Using filesort
flush status; select ...; show session status like 'Handler%';
Variable_name | Value
Handler_commit | 1
Handler_delete | 0
Handler_discover | 0
Handler_external_lock | 2
Handler_mrr_init | 0
Handler_prepare | 0
Handler_read_first | 1
Handler_read_key | 1001
Handler_read_last | 0
Handler_read_next | 0
Handler_read_prev | 0
Handler_read_rnd | 1000
Handler_read_rnd_next | 119395
Handler_rollback | 0
Handler_savepoint | 0
Handler_savepoint_rollback | 0
Handler_update | 0
Handler_write | 0
st_...
函数。 - O. JonesST_Distance_Sphere()
。 - Rick James