mysql5.7 geometry类型的使用

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_32080545/article/details/79043010

insert:
假设数据表A中的geometry类型的字段是‘location’,则添加的语句是:

 insert into A('id','name','location') value(null,'测试数据',ST_GeomFromText('POINT(104.066143 30.573095)'));

POINT函数里面的参数左边是经度,右边是纬度,改变值
(update)也是一样的用法。

select
获取坐标信息:

SELECT  ASTEXT(location) AS location FROM  A 

计算两点之间的距离:

select  ST_Distance_Sphere (POINT(104.079971, 30.554951),location) AS distant from A 

(以上坐标是随便找的坐标,左边是经度右边是纬度,不要定位来轰炸我。。。)

距离筛选,比如5公里范围内的数据:

select id,name, ST_Distance_Sphere (POINT(104.079971, 30.554951),location) AS distant from A where ST_Distance_Sphere (POINT(104.079971, 30.554951),location) < 5000 ORDER BY distant

目前我的mysql版本是5.7.17( select @@version;可查自己的版本),越新的版本可以使用的函数更多,详情请参考:MYSQL官网

写在最后:经测试当距离范围为1000米的时候,查询的数据没有找到自身的坐标,不知道是不是一个bug,基于这个原因目前项目计算距离范围还是使用的更稳健的redis3.2的GEO,具体使用请参考:redis GEO地理位置

猜你喜欢

转载自blog.csdn.net/qq_32080545/article/details/79043010
今日推荐