婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > postgresql 計算距離的實例(單位直接生成米)

postgresql 計算距離的實例(單位直接生成米)

熱門標簽:電話機器人怎么換人工座席 400電話申請客服 廣州電銷機器人公司招聘 地圖標注要花多少錢 江蘇400電話辦理官方 電銷機器人能補救房產中介嗎 濟南外呼網絡電話線路 天津開發區地圖標注app 移動外呼系統模擬題

之前用的是ST_Distance 函數,但是貌似需要進行一次單位的轉換,而且網上有說那種轉換不是特別準確,現在暫時將該算法記錄在此:

select st_distance(ST_GeomFromText('POINT(120.451737 36.520975)',900913),ST_GeomFromText('POINT(120.455636 36.520885)',900913))*60*1.852;

這里的計算方式倒是可以換坐標系,但是,測試了兩個坐標系都沒有起作用。而且該種方式轉換過單位后跟arcgis計算出的結果相差甚遠,最終決定使用下面的方式;

今天發現了另外一種方式來計算距離,這種方式可以直接生成單位為米的結果:

select ST_Length(Geography(ST_GeomFromText('LINESTRING(120.451737 36.520975,120.455636 36.520885)')));

這種方式的不便在于:

1.要把點轉換成線或者其他的圖形而不是點;

2.geography函數現在只支持4326坐標系,不能換成其他的。

追加:

上面的方式是計算點到點的距離,但是如果要想知道某一個點到某條線的距離是不是在某個范圍內,又該如何計算呢;如下:

select ST_Contains(St_Astext(ST_Buffer(geography(geomfromtext('MULTILINESTRING((線的坐標點))')),25.00{以米為單位的距離})),st_astext(geography(geomfromtext('POINT(121.37805 37.54142)')))) as result

使用類似上面的方式,就可以輸入以米為單位的距離判斷某個點是否在某個距離范圍內;

補充:postgresql 搜索指定距離內的記錄 按近到遠排序 并返回距離

實例如下:

CREATE TABLE mylocation ( 
 id SERIAL PRIMARY KEY,
 geom GEOMETRY(Point, 4326),
 name VARCHAR(128),
 x double precision,
 y double precision
); 
 
INSERT INTO mylocation (geom,name,x,y) VALUES (
 ST_GeomFromText('POINT(0.0001 0)', 4326),'zhangsan',0.0001,0
);
INSERT INTO mylocation (geom,name,x,y) VALUES (
 ST_GeomFromText('POINT(0.001 0)', 4326),'zhangsan',0.001,0
);
INSERT INTO mylocation (geom,name,x,y) VALUES (
 ST_GeomFromText('POINT(0.001 0)', 4326),'zhangsan',0.001,0
);
INSERT INTO mylocation (geom,name,x,y) VALUES (
 ST_GeomFromText('POINT(0.1 0)', 4326),'zhangsan',0.1,0
); 
 
SELECT id, name,geom,x,y,  ST_DistanceSphere(
           geom,
           ST_GeometryFromText('POINT(0 0)')) distance
FROM mylocation
WHERE ST_DWithin(
 geom, 
 ST_GeomFromText('POINT(0 0)', 4326),
 0.001
)ORDER BY distance asc;;

查詢語句 下面距離單位為m

SELECT id, name,geom,x,y,  ST_DistanceSphere(
           geom,
           ST_GeometryFromText('POINT(0 0)')) distance
FROM mylocation
WHERE ST_DWithin(
 geom::geography, 
 ST_GeomFromText('POINT(0 0)', 4326)::geography,
 1000
) ORDER BY distance asc;

搜索結果

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

您可能感興趣的文章:
  • PostgreSQL中enable、disable和validate外鍵約束的實例
  • PostgreSQL 修改視圖的操作
  • PostgreSQL 更新視圖腳本的注意事項說明
  • postgreSQL中的row_number() 與distinct用法說明
  • Postgresql 動態統計某一列的某一值出現的次數實例
  • postgresql 計算兩點距離的2種方法小結
  • PostgreSQL 查看表的主外鍵等約束關系詳解

標簽:杭州 寶雞 辛集 濮陽 昭通 海西 榆林 溫州

巨人網絡通訊聲明:本文標題《postgresql 計算距離的實例(單位直接生成米)》,本文關鍵詞  postgresql,計算,距離,的,實例,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《postgresql 計算距離的實例(單位直接生成米)》相關的同類信息!
  • 本頁收集關于postgresql 計算距離的實例(單位直接生成米)的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 襄垣县| 新乡县| 连南| 阳谷县| 丘北县| 达拉特旗| 临猗县| 偃师市| 上林县| 武威市| 定远县| 太原市| 济阳县| 湖州市| 图木舒克市| 香港| 台中市| 界首市| 鹤峰县| 新化县| 河津市| 沙田区| 平江县| 安阳市| 农安县| 东乡| 巴南区| 治县。| 尚义县| 金溪县| 甘孜| 鲁山县| 盐边县| 大城县| 磐石市| 龙口市| 芒康县| 耿马| 达州市| 锦州市| 精河县|