獲取資料庫中到指定經緯度距離的座標
oracle儲存過程
新專案需求:
結合百度地圖,在地圖中指定一個地點,獲取此地點周圍1km範圍內所有資料庫中存的單位的地點和資訊標記在地圖上。於是初寫了一把oracle
的儲存過程,純靠摸索寫的。
後臺需要的函式如下:
首先,計算圓弧函式
CREATE OR REPLACE FUNCTION RAD(d number) RETURN NUMBER
is
PI number :=3.141592625;
begin
return d* PI/180.0;
end ;
然後,計算距離函式
CREATE OR REPLACE FUNCTION GetDistance(lat1 number,
lng1 number,
lat2 number,
lng2 number) RETURN NUMBER is
earth_padius number := 6378.137;
radLat1 number := rad(lat1);
radLat2 number := rad(lat2);
a number := radLat1 - radLat2;
b number := rad(lng1) - rad(lng2);
s number := 0;
begin
s := 2 *
Asin(Sqrt(power(sin(a / 2), 2) +
cos(radLat1) * cos(radLat2) * power(sin(b / 2), 2)));
s := s * earth_padius;
s := Round(s * 10000) / 10000;
return s;
end;
接下來是我自己寫的儲存過程:
CREATE OR REPLACE PROCEDURE distance_maintunit(p_cur out sys_refcursor, center_lat in number , center_lng in number)
IS
v_muids VARCHAR(200);
v_distance NUMERIC(9,6);
BEGIN
FOR L_RECORD IN (select * from M_MAINTENACEUNIT)
LOOP
SELECT GetDistance(L_RECORD.Lat,L_RECORD.Longitude,center_lat,center_lng) INTO v_distance FROM dual;
/*dbms_output.put_line('distance:' || v_distance);*/
IF (v_distance <=1)
THEN
v_muids:= v_muids || L_RECORD.muid || ',';
END IF;
END LOOP;
v_muids:= v_muids || '-1';
dbms_output.put_line(v_muids);
open p_cur for 'select * from m_maintenaceunit where muid in ('||v_muids||')';
EXCEPTION
WHEN OTHERS THEN
ROLLBACK;
dbms_output.put_line(SQLERRM);
END;
由於使用mybatis
,所以service
呼叫如下:
@Override
public List<MaintunitDto> getMaitunitByProcedures(Double lat, Double lng) {
Map<String ,Object> map=new HashMap<String, Object>();
map.put("lng", lng);
map.put("lat", lat);
try {
geoDao.getMaitunitByProcedures(map);
}catch(UncategorizedSQLException e) {
// System.out.println(e);
e.printStackTrace();
}
@SuppressWarnings("unchecked")
List<MaintunitDto> siteList=(List<MaintunitDto>)map.get("maintunits");
return siteList;
}
這裡跟我之前轉載的那篇關於oracle
儲存過程的文章有關聯(如何呼叫一個返回集合的儲存過程)
mapper.xml
中的呼叫:
<select id="getMaitunitByProcedures" statementType="CALLABLE" parameterType="java.util.Map">
<![CDATA[
{call distance_maintunit(
#{maintunits,jdbcType=CURSOR,mode=OUT,resultMap=MAINTUNIT_MAP,javaType=ResultSet},
#{lat,jdbcType=DOUBLE,mode=IN},
#{lng,jdbcType=DOUBLE,mode=IN}
)}
]]>
</select>
<resultMap type="com.cseds.geo.dto.MaintunitDto" id="MAINTUNIT_MAP">
</resultMap>
dao
中呼叫:
public List<MaintunitDto> getMaintUnitList(@Param("lng") Double lng, @Param("lat") Double lat);
由於第一次寫oracle
儲存過程,程式碼只是實現了功能,有待改進。
在 Oracle 中根據經緯度計算兩地之間的距離
在 Oracle 中根據經緯度計算兩地之間的距離
獲得弧度的函式:
CREATE OR REPLACE FUNCTION Radian(d number) RETURN NUMBER
is
PI number :=3.141592625;
begin
return d* PI/180.0;
end ;
測試一下這個函式:
select Radian(360) from dual;
根據經緯度計算距離的函式:
CREATE OR REPLACE FUNCTION GetDistance(lat1 number,
lng1 number,
lat2 number,
lng2 number) RETURN NUMBER is
earth_padius number := 6378.137;
radLat1 number := Radian(lat1);
radLat2 number := Radian(lat2);
a number := radLat1 - radLat2;
b number := Radian(lng1) - Radian(lng2);
s number := 0;
begin
s := 2 *
Asin(Sqrt(power(sin(a / 2), 2) +
cos(radLat1) * cos(radLat2) * power(sin(b / 2), 2)));
s := s * earth_padius;
s := Round(s * 10000) / 10000;
return s;
end;
示例,根據城市名計算距離:
東方明珠塔的經緯度是:121.506656,31.245087
陸家嘴地鐵站的經緯度是:121.508883,31.243481
SQL> select GetDistance('121.506656','31.245087','121.508883','31.243481') from dual;
輸出結果是 0.2649 千米
sql server 計算兩個經緯度點之間的距離
這裡用到的演算法和地球半徑等資料均來自網路,此文只作整理記錄。
地球半徑值採用赤道半徑 6378137.0
米,這是1980
年的國際標準資料。
下面是在資料庫中寫的自定義函式,傳入兩個經緯度點的資料,共4個引數,返回以米為單位的兩點之間的距離
CREATE FUNCTION [f_GetDistance]
(
@GPSLng DECIMAL(12,6),
@GPSLat DECIMAL(12,6),
@Lng DECIMAL(12,6),
@Lat DECIMAL(12,6)
)
RETURNS DECIMAL(12,4)
AS
BEGIN
DECLARE @result DECIMAL(12,4)
SELECT @result = 6378137.0*ACOS(SIN(@GPSLat/180*PI())*SIN(@Lat/180*PI())+COS(@GPSLat/180*PI())*COS(@Lat/180*PI())*COS((@GPSLng-@Lng)/180*PI()))
RETURN @result
END
GO
相關文章
- 透過經緯度計算距離獲取附近商家
- java 經緯度處理、計算兩地的距離、獲取當前一定距離以內的經緯度值Java
- 簡單計算給定兩個給定經緯度座標的距離
- 經緯度距離換算
- java 經緯度處理、計算兩地的距離、獲取當前一定距離以內的經緯度值 2022-02-14 0Java
- JAVA計算兩經緯度間的距離Java
- 微信小程式 計算兩地之間的距離 + 高德地圖獲取經緯度 + elasticsearch微信小程式地圖Elasticsearch
- mapbox獲取各種經緯度
- Elasticsearch 7.2 在 Laravel 中實踐 --經緯度及距離查詢ElasticsearchLaravel
- 如何快速將地址解析為經緯度座標?
- java 根據兩個位置的經緯度,來計算兩地的距離 經緯度處理Java
- 通過sql 計算兩經緯度之間的距離SQL
- 根據經緯度座標查詢最近的門店
- 使用MySQL的geometry型別處理經緯度距離問題MySql型別
- 根據經緯度計算兩點之間的距離的公式公式
- JavaScript獲取元素距離文件頂部的距離JavaScript
- java百度地圖介面呼叫獲取經緯度Java地圖
- 如何使用Python經緯座標模組?Python
- 根據兩點經緯度計算距離和角度——java實現Java
- JavaScript獲取滑鼠在元素中的座標JavaScript
- 根據經緯度座標獲得省市區縣行政區劃城市名稱,自建資料庫 java python php c# .net 均適用資料庫JavaPythonPHPC#
- C#根據經緯度獲取實體地址C#
- JavaScript 中那些關於座標和距離的屬性與方法JavaScript
- springboot + mongodb 通過經緯度座標匹配平面區域的方法YWKSSpring BootMongoDB
- JavaScript獲取元素在文件中座標JavaScript
- JavaScript獲取滑鼠在文件中座標JavaScript
- python獲取指定影片解析度並移動到相應的資料夾中-2Python
- 通過經緯度計算距離實現附近、附近的人等功能
- PHP實現透過經緯度計算距離和查附近店門PHP
- 原生JS獲取DOM 節點到瀏覽器頂部的距離或者左側的距離JS瀏覽器
- python將目標檢測資料匯入到指定資料庫中Python資料庫
- .NET程式獲取當前IP經緯度,並透過經緯度實現天氣查詢功能
- 智慧手環WIFI熱點和經緯度API獲取WiFiAPI
- 如何透過裝置基站獲取裝置經緯度
- 百度地圖:根據位置獲取座標地圖
- 如何判斷一個指定的位置點座標(GPS上的經緯度)是否落在一個多邊形區域內?
- 3-點的座標及最遠距離問題
- JavaScript 獲取div在頁面中座標JavaScript