您的位置:首頁技術文章
文章詳情頁

lbs - Mysql POINT類型數據,怎么計算經緯度偏差

瀏覽:81日期:2022-06-15 17:52:56

問題描述

使用新的point類型存儲經緯度,現在要將GPS坐標轉換成bd坐標,需計算其兩值偏差,如果單獨拿出經度、緯度計算的話不能完整的利用數據庫的索引,如果直接使用point類型計算其經緯度差值,需要用什么方法?

問題解答

回答1:

多謝關注回答;研究了下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 existLINE 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文件導進去的,最后總結,自己寫個函數吧,可能更快些,用這個沒必要!

回答2:

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

国产综合久久一区二区三区