共计 893 个字符,预计需要花费 3 分钟才能阅读完成。
自动写代码机器人,免费开通
这篇文章给大家分享的是有关 MySQL 中 geometry 类型如何处理经纬度距离的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考。一起跟随丸趣 TV 小编过来看看吧。
建表
CREATE TABLE `map` (`id` int(11) NOT NULL,
`address` varchar(255) NOT NULL DEFAULT ,
`location` geometry NOT NULL,
PRIMARY KEY (`id`),
SPATIAL KEY `idx_location` (`location`)
)
插入
INSERT INTO map (id, address, location) VALUES (1, somewhere , ST_GeomFromText( POINT(121.366961 31.190049)
注意必须使用 ST_GeomFromText 函数,且 POINT() 里面是:经度 + 空格 + 纬度查询 1. 查看经纬度
SELECT address, ST_AsText(location) AS location FROM map;
2. 计算两点之间的距离
SELECT ST_Distance_Sphere(POINT(121.590347, 31.388094),location) AS distant FROM map;
算出来的结果,单位是米
注意现在 POINT()里面经纬度之间是逗号分隔的 3. 查询距离小于 1000m 的地点,并由远及近排序
SELECT id, address, ST_Distance_Sphere(POINT(121.590347, 31.388094),location) AS distant FROM map WHERE ST_Distance_Sphere(POINT(121.590347, 31.388094),location) 1000 ORDER BY distant;
感谢各位的阅读!关于 MySQL 中 geometry 类型如何处理经纬度距离就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!
向 AI 问一下细节
丸趣 TV 网 – 提供最优质的资源集合!
正文完