回答

收藏

如何从PostgreSQL转换为GeoJSON格式?

技术问答 技术问答 205 人阅读 | 0 人回复 | 2023-09-14

有一个叫我# g/ D2 F3 f7 L( j( r
imposm3_restaurant列出的简单表[id,name,geometry],我想把这些数据转换成geoJSON,我正在使用这个功能
( w( t3 w! L5 F, b& OCREATE VIEW imposm3_restaurants_geojson AS SELECT row_to_json(fc) AS geojson FROM (SELECT 'FeatureCollection' As type,array_to_json(array_agg(f))As features FROM (SELECT 'Feature' As type,ST_AsGeoJSON((lg.geometry),15,0)::json As geometry,row_to_json((id,name)) As propertiesFROM imposm3_restaurants As lg) As f ) As fc;结果如下:. ]' X# H5 ]0 [& o& r* l9 ]' _8 z
{"type":"FeatureCollection","features":[{"type":"Feature","geometry":{"type":"LineString","coordinates":[[2615020.47191046,5899232.25158985],[2615034.50527113,5899231.67978097],[2615033.86145338,5899215.4513157],[2615032.35921198,5899215.51938806],[2615031.96732292,5899205.64890158],[2615034.97180572,5899205.51275702],[2615034.36531075,5899190.07397728],[2615018.19522163,5899190.71385561],[2615018.77372453,5899205.40384137],[2615020.47191046,5899205.32215463],[2615020.91045298,5899216.48601561],[2615019.83742341,5899216.52685903],[2615020.47191046,5899232.25158985]]},"properties":{"f1":2719,"f2":"Atelierul de Pizza"}},{"type":"Feature","geometry":{"type":&quotolygon","coordinates":[[[2615018.19522163,5899190.71385561],[2615018.77372453,5899205.40384137],[2615020.47191046,5899205.32215463],[2615020.91045298,5899216.48601561],[2615019.83742341,5899216.52685903],[2615020.47191046,5899232.25158985],[2615034.50527113,5899231.67978097],[2615033.86145338,5899215.4513157],[2615032.35921198,5899215.51938806],[2615031.96732292,5899205.64890158],[2615034.97180572,5899205.51275702],[2615034.36531075,5899190.07397728],[2615018.19522163,5899190.71385561]]]},"properties":{"f1":2720,"f2":"Atelierul de Pizza"}},{"type":"Feature","geometry":{"type":"LineString","coordinates":[[2624875.82864931,5903443.39761349],[2624897.49451598,5903452.78251964],[2624901.44139867,5903443.67003443],[2624879.78486269,5903434.29875908],[2624875.82864931,5903443.39761349]]},"properties":{"f1":2986,"f2":&quotizza Acrobatica"}},{"type":"Feature","geometry":{"type":&quotolygon","coordinates":[[[2624875.82864931,5903443.39761349],[2624897.49451598,5903452.78251964],[2624901.44139867,5903443.67003443],[2624879.78486269,5903434.29875908],[2624875.82864931,5903443.39761349]]]},"properties":{"f1":2988,"f2":&quotizza Acrobatica"}},{"type":"Feature","geometry":{"type":"LineString","coordinates":[[2622460.22447654,5904586.41424973],[2622479.10046632,5904587.95362911],[2622480.25747212,5904573.81314552],[2622461.39081303,5904572.26014582],[2622460.22447654,5904586.41424973]]},"properties":{"f1":3248,"f2":"Casa Vikingilor"}},{"type":"Feature","geometry":{"type":&quotolygon","coordinates":[[[2622460.22447654,5904586.41424973],[2622479.10046632,5904587.95362911],[2622480.25747212,5904573.81314552],[2622461.39081303,5904572.26014582],[2622460.22447654,5904586.41424973]]]},"properties":{"f1":3249,"f2":"Casa Vikingilor"}},{"type":"Feature","geometry":{"type":"LineString","coordinates":[[2625201.09657005,5897608.45120294],[2625224.46062264,5897614.30435379],[2625241.33051365,5897576.653689],[2625213.43174478,5897570.82778714],[2625201.09657005,5897608.45120294]]},"properties":{"f1":6152,"f2":"Silva"}},{"type":"Feature","geometry":{"type":&quotolygon","coordinates":[[[2625201.09657005,5897608.45120294],[2625224.46062264,5897614.30435379],[2625241.33051365,5897576.653689],[2625213.43174478,5897570.82778714],[2625201.09657005,5897608.45120294]]]},"properties":{"f1":6153,"f2":"Silva"}},{"type":"Feature","geometry":{"type":"LineString","coordinates":[[2622825.25980629,5904372.27967993],[2622826.15555271,5904353.45341631],[2622834.51585268,5904353.1673446],[2622854.22227404,5904346.00193242],[2622860.03529512,5904362.26715407],[2622856.61093118,5904374.66361634],[2622825.25980629,5904372.27967993]]},"properties":{"f1":6322,"f2":"Restaurant Sinaia"}},{"type":"Feature","geometry":{"type":&quotolygon","coordinates":[[[2622825.25980629,5904372.27967993],[2622856.61093118,5904374.66361634],[2622860.03529512,5904362.26715407],[2622854.22227404,5904346.00193242],[2622834.51585268,5904353.1673446],[2622826.15555271,5904353.45341631],[2622825.25980629,5904372.27967993]]]},"properties":{"f1":6323,"f2":"Restaurant Sinaia"}}]}它没有当前的几何图形。你知道功能有什么问题吗?我用的是Postgres 9.3和PostGIS 2.2) P# [+ n% Z' [4 ~; i8 p
                                                                & v& ~' d6 {: i- Y# X
    解决方案:                                                               
; i7 e' e: e; Y  O: B- G: }                                                                您的输出是有效的geojson文件,但使用投影EPSG:3857投影几何。
4 X" K4 C' c8 i; b& ]2 o, g大部分都可以gis桌面应用程序(例如Quantum Gis)在没有问题的情况下加载数据。
% j- h0 w8 Q7 u, ~" ^! H0 \geojson.io可能只支持长/纬坐标EPSG:还尝试使用函数4326St_Transform将几何重新投影到长/纬坐标上: g/ m8 q, U' }3 B
更改此行:( F0 O" ~6 b6 K( q0 q5 n
ST_AsGeoJSON((lg.geometry),15,0)::json As geometry,在此:
8 D+ ]9 h" M4 K( ~  C; sST_AsGeoJSON(ST_Transform(lg.geometry,4326),15,0):json As geometry,
分享到:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则