首頁  >  問答  >  主體

lbs - Mysql POINT类型数据,怎么计算经纬度偏差

使用新的point类型存储经纬度,现在要将GPS坐标转换成bd坐标,需计算其两值偏差,如果单独拿出经度、纬度计算的话不能完整的利用数据库的索引,如果直接使用point类型计算其经纬度差值,需要用什么方法?

高洛峰高洛峰2742 天前623

全部回覆(2)我來回復

  • 黄舟

    黄舟2017-04-17 16:19:04

    多謝關注回答;
    研究了下MySql官方文件(5.7第13章15節page1752開始),有很多關於地理位置、空間的函數可用,例如1樓所提醒的ST_Distance函數,還有ST_Intersects()計算兩點相同屬性,ST_Difference()計算兩點的不同屬性,ST_Buffer()計算的是偏差?
    試了很多還是不行,再研究PostGis官方文檔(2.3版本,第14章page685開始),這個支持函數貌似更多,看到了ST_Summary想直接加出偏差值,將GPS坐標轉換為bd,但是呢,這個

    mysql> SELECT ST_Summary(point(3,4),POINT(4,5));
    ERROR 1305 (42000): FUNCTION ST_Summary does not exist
    
    ERROR:  function st_summary(point, point) does not exist
    LINE 1: SELECT ST_Summary(point(3,4),POINT(4,5));
                   ^
    HINT:  No function matches the given name and argument types. You might need to add explicit type casts.
    

    讓我很傷心啊

    再來OpenGIS文檔,這個是沒有介紹通用函數的,基本介紹使用方法,又回頭研究了下PostGIS的自帶函數,是安裝時直接用sql文件導進去的,最後總結,自己寫個函數吧,可能更快些,用這個沒必要!

    回覆
    0
  • PHP中文网

    PHP中文网2017-04-17 16:19:04

    謝邀,不是很熟悉point,粗略查了下資料,希望對你有幫助 傳送門

    回覆
    0
  • 取消回覆