我有一个 Geocoordinateable 类,它为模型提供了一些处理地理坐标的有用方法。其中包括“geocoordinates=”,它接受一个数组。

https://gist.github.com/mboyle/58dd3add830bbdeef316

您可以调用“geocoordinates”来获取数组中的坐标:

irb(main):056:0> b.geocoordinates
=> [-118.25, 34.197]

当我像这样分配坐标时:
irb(main):058:0> b.geocoordinates = [34.197, -118.25]
   (1.8ms)
 UPDATE users
 SET geocoordinates = 'SRID=4326;POINT(' || 34.197 || ' ' || -118.25 || ')'
 WHERE id = 347708

   (0.7ms)
 UPDATE activities
 SET geocoordinates = users.geocoordinates
 FROM users
 WHERE activities.user_id = users.id
 AND users.id = 347708
 AND NOT postgis.ST_Equals(activities.geocoordinates, users.geocoordinates)

=> [34.197, -118.25]

事情似乎可以保存并正确显示。但是,如果我再次查询模型,然后读取地理坐标,则经纬度会反转:
irb(main):059:0> b = User.find(b.id)
irb(main):060:0> b.geocoordinates
   (0.7ms)
 SELECT postgis.ST_Y(geocoordinates) AS latitude, postgis.ST_X(geocoordinates) AS longitude
 FROM users
 WHERE id = 347708

=> [-118.25, 34.197]

我一生都无法理解为什么会发生这种情况。有人有线索吗?

最佳答案

在 PostGIS 中,坐标按 (X, Y) 顺序设置,或为地理坐标对设置(经度、纬度)。所以你应该这样做:

UPDATE users
SET geocoordinates = 'SRID=4326;POINT(' || -118.25 || ' ' || 34.197 || ')'
WHERE id = 347708

然后可能也是:
irb(main):058:0> b.geocoordinates = [-118.25, 34.197]

请注意,PostGIS 以 OGC 指定的众所周知的文本 (WKT) 格式摄取文本数据。该标准规定了 (X,Y) 或 (lon,lat) 顺序。所以这不是一个选择,它需要使 PostGIS 能够摄取其他 OGC 兼容软件生成的 WKT 文件。摄取 WKT 后,PostGIS 以其内部格式存储数据,实际上是稍加修改的 OGC Well-Known Binary (WKB) 格式,在具有 PostGIS 定义的 geometrygeography 数据类型的列中,然后数据可以以最终用户所需的任何形式进行分析和呈现。

关于ruby-on-rails - Postgis纬度/经度读取反向,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/29935651/

10-13 08:49