lbs - Mysql POINT類型數(shù)據(jù),怎么計(jì)算經(jīng)緯度偏差
問題描述
使用新的point類型存儲(chǔ)經(jīng)緯度,現(xiàn)在要將GPS坐標(biāo)轉(zhuǎn)換成bd坐標(biāo),需計(jì)算其兩值偏差,如果單獨(dú)拿出經(jīng)度、緯度計(jì)算的話不能完整的利用數(shù)據(jù)庫(kù)的索引,如果直接使用point類型計(jì)算其經(jīng)緯度差值,需要用什么方法?
問題解答
回答1:多謝關(guān)注回答;研究了下MySql官方文檔(5.7第13章15節(jié)page1752開始),有很多關(guān)于地理位置、空間的函數(shù)可用,比如1樓所提醒的ST_Distance函數(shù),還有ST_Intersects()計(jì)算兩點(diǎn)相同屬性,ST_Difference()計(jì)算兩點(diǎn)的不同屬性,ST_Buffer()計(jì)算的是偏差?試了很多還是不行,再研究PostGis官方文檔(2.3版本,第14章page685開始),這個(gè)支持函數(shù)貌似更多,看到了ST_Summary想直接加出偏差值,將GPS坐標(biāo)轉(zhuǎn)換為bd,但是呢,這個(gè)
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文檔,這個(gè)是沒有介紹通用函數(shù)的,基本介紹使用方法,又回頭研究了下PostGIS的自帶函數(shù),是安裝時(shí)直接用sql文件導(dǎo)進(jìn)去的,最后總結(jié),自己寫個(gè)函數(shù)吧,可能更快些,用這個(gè)沒必要!
回答2:謝邀,不是很熟悉point,粗略查了下資料,希望對(duì)你有幫助 傳送門
