gpt4 book ai didi

mysql - 在 MySQL 8 中使用点数据类型和 st_distance_sphere 查找最近的地方

转载 作者:可可西里 更新时间:2023-11-01 07:38:26 26 4
gpt4 key购买 nike

我有一个名为 place 的表:

id | name       | coordinates (longitude, latitude)
1 | London | -0.12574, 51.50853
2 | Manchester | -2.25, 53.41667
3 | Glasgow | -4.25, 55.86667

坐标 列是点数据类型。我使用以下方法将点插入到 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;

在查看了此处和其他地方的无数类似问题后,很明显这是一种鲜为人知(且较新的方式)的做事方式,因此没有太多内容,因此我需要一些说明.

我的问题是:

  1. 这是最好的解决方案吗/我这样做对吗?
  2. 此方法是否会使用我在 coordinates 列上的空间索引?
  3. 使用 st_distance_sphere 时,是否需要指定地球的半径才能获得准确的结果? (编辑:不,它默认使用地球的半径)

编辑,这里是那些答案:

解释 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

刷新状态;选择 ...;显示 session 状态,如“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

最佳答案

可能是最好的解决方案。让我们先得到一些其他的答案......

EXPLAIN SELECT ... 说了什么? (这可能会回答您的问题 2)。

无论其他答案如何,您的查询都将扫描整个表。也许你想要 LIMIT ... 最后?

另一件可能有用的事情(取决于您的应用程序和优化器):将边界框添加到 WHERE 子句。

无论如何,请执行以下操作以准确了解实际触摸了多少行:

FLUSH STATUS;
SELECT ...;
SHOW SESSION STATUS LIKE 'Handler%';

返回这些答案;那么也许我们可以进一步迭代。

显示状态后

嗯,Handler_read_rnd_next 说这是全表扫描。 1000 和 1001 -- 你有 LIMIT 1000 吗?

我推断 LIMIT 并未影响 SPATIAL 的工作方式。也就是说,它做的事情很简单——(1) 检查所有行,(2) 排序,(3) LIMIT

那么,怎么办?

计划 A:确定您不希望得到比 X 英里 (km) 更远的结果,并向查询添加一个“边界框”。

B 计划:放弃 Spatial 并挖掘更复杂的方法来完成任务:http://mysql.rjweb.org/doc.php/latlng

关于mysql - 在 MySQL 8 中使用点数据类型和 st_distance_sphere 查找最近的地方,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50438381/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com