polyGON((50.4668 -6.90665,51.73607 0.14657,55.3032 -4.52724,50.4668 -6.90665))
我想像这样用MariaDB计算该多边形的面积:
SELECT ST_Area(ST_GeomFromText('polyGON((50.4668 -6.90665,51.73607 0.14657,55.3032 -4.52724,50.4668 -6.90665))'))
上面的查询结果是15.546039738650009,这是错误的.我使用this工具计算了多边形的面积,得出119116192747.1.
如何使mariaDB理解此多边形包含经度和纬度以正确计算面积?
解决方法:
In MariaDB, the SRID value is just an integer associated with the geometry value. All calculations are done assuming Euclidean (planar) geometry.
但是,在MysqL 8.0.13中提供了此功能,您可以使用ST_Area()计算多边形面积:
Incompatible Change: PrevIoUsly, ST_Area() supported only geometry arguments having a Cartesian spatial reference system (SRS) and produced an error when invoked with geometry arguments that specified a geographic SRS. ST_Area() Now supports geometry arguments having a geographic SRS and returns the geodetic area in square meters.
因此,如果您将数据库更改为MysqL> 8.0.13您可以使用以下查询计算多边形面积:
SELECT ST_Area(ST_polyFromText('polyGON((50.4668 -6.90665,51.73607 0.14657,55.3032 -4.52724,50.4668 -6.90665))', 4326));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。