MySQL空間函數(shù)ST_Distance_Sphere()的使用方式
空間函數(shù)ST_Distance_Sphere()的使用
返回球體上兩個(gè)點(diǎn)和/或多點(diǎn)之間的最小球面距離(以米為單位)
官網(wǎng)(https://dev.mysql.com/doc/refman/5.7/en/spatial-convenience-functions.html)

測(cè)試
表結(jié)構(gòu)如下:
create table t_geo_test
(
ID int auto_increment
primary key,
NAME varchar(64) not null,
SHAPE geometry not null
)
engine = InnoDB
charset = utf8;測(cè)試數(shù)據(jù):(插入坐標(biāo)時(shí),以下兩種寫法都可以)
INSERT INTO t_geo_test VALUES (1, '測(cè)試', POINT(121.590347, 31.388094));
INSERT INTO t_geo_test VALUES (2, 'somewhere', ST_GeomFromText('POINT(121.366961 31.190049)'));
計(jì)算距離:
SELECT st_distance_sphere(POINT(121.590347, 31.388094),SHAPE) AS distant FROM t_geo_test;
查詢到某點(diǎn)的距離小于一個(gè)值的所有數(shù)據(jù):
SELECT *, ST_Distance_Sphere(POINT(121.590347, 31.388094),SHAPE) AS distant FROM t_geo_test WHERE ST_Distance_Sphere(POINT(121.590347, 31.388094),SHAPE) < 1000 ORDER BY distant;
注意:
坐標(biāo)不能隨意寫測(cè)試數(shù)據(jù),注意官網(wǎng)中的說(shuō)的條件:
- 幾何參數(shù)應(yīng)由指定(經(jīng)度,緯度)坐標(biāo)值的點(diǎn)組成:
- 經(jīng)度和緯度分別是該點(diǎn)的第一和第二坐標(biāo)。
- 兩個(gè)坐標(biāo)均以度為單位。
- 經(jīng)度值必須在(-180,180]范圍內(nèi)。正值位于本初子午線以東。
- 緯度值必須在[-90,90]范圍內(nèi)。正值位于赤道以北。
否則則會(huì)報(bào)錯(cuò):
[HY000][1210] Incorrect arguments to st_distance_sphere
st_distance_sphere計(jì)算兩坐標(biāo)點(diǎn)距離
最近項(xiàng)目中需要計(jì)算一個(gè)坐標(biāo)點(diǎn)與多個(gè)點(diǎn)的距離,發(fā)現(xiàn)用Python來(lái)實(shí)現(xiàn)效率很低。經(jīng)同事推薦,將這些坐標(biāo)點(diǎn)存入了Mysql數(shù)據(jù)庫(kù),然后用數(shù)據(jù)庫(kù)自帶的方法st_distance_sphere計(jì)算距離。經(jīng)過(guò)比較發(fā)現(xiàn)確實(shí)效率提高了很多,特此記錄一下。
注意:使用st_distance_sphere需要Mysql數(shù)據(jù)庫(kù)版本為5.7及以上。
例子
現(xiàn)數(shù)據(jù)庫(kù)表中有如下坐標(biāo)點(diǎn)數(shù)據(jù):

需要找出與第一個(gè)坐標(biāo)點(diǎn)(113.8064049, 22.7300434)相距小于3500米的坐標(biāo)點(diǎn)(表中共有3500個(gè)點(diǎn))。
sql實(shí)現(xiàn):
select t.num,t.city,t.wgs84_lng,t.wgs84_lat, TRUNCATE(st_distance_sphere(point (113.8064049, 22.7300434),point(t.wgs84_lng,t.wgs84_lat)),2) as distance from moran_point t where t.city = '深圳' HAVING distance > 0 and distance < 3500 ORDER BY distance;
查詢結(jié)果:

可以看到,共找出41個(gè)滿足條件的坐標(biāo)點(diǎn),且耗時(shí)僅為0.066秒,效率提升非常多。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
完美轉(zhuǎn)換MySQL的字符集 解決查看utf8源文件中的亂碼問(wèn)題
本人轉(zhuǎn)換過(guò)好多數(shù)據(jù)了,也用過(guò)了好多的辦法,個(gè)人感覺(jué)最好用的就是使用MySQL命令導(dǎo)出導(dǎo)入中將字符集轉(zhuǎn)換過(guò)去2011-11-11
Mysql數(shù)據(jù)庫(kù)增量備份的思路和方法
MySQL數(shù)據(jù)庫(kù)增量備份,在這之前修改我們的數(shù)據(jù)庫(kù)配置文件/etc/my.cnf開(kāi)啟bin-log日志功能即可,下面小編給大家分享Mysql數(shù)據(jù)庫(kù)增量備份的思路詳解,一起看看吧2017-09-09
MySQL提示表不存在的解決error:1146:Table doesn‘t exist的原因和解決
在使用MySQL的過(guò)程中,有時(shí)會(huì)遇到“Table doesn't exist”(表不存在)的錯(cuò)誤,錯(cuò)誤代碼通常為1146,這個(gè)問(wèn)題可能由多種原因引起,本文將幫助你診斷和解決這個(gè)問(wèn)題,如果遇到同樣問(wèn)題的小伙伴跟著小編一起來(lái)看看吧2024-12-12
innodb如何巧妙的實(shí)現(xiàn)事務(wù)隔離級(jí)別詳解
隔離是ACID(Atomicity,Consistency,Isolation,Durability)的重要部分,下面這篇文章主要給大家介紹了關(guān)于innodb如何巧妙的實(shí)現(xiàn)事務(wù)隔離級(jí)別的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2018-11-11
MySQL 使用SQL語(yǔ)句修改表名的實(shí)現(xiàn)
這篇文章主要介紹了MySQL 使用SQL語(yǔ)句修改表名的實(shí)現(xiàn)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2021-04-04

