mysql-ST_Area()用于纬度和经度

mysql-ST_Area()用于纬度和经度,第1张

概述我有一个包含MariaDB中多个坐标的多边形: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.906

我有一个包含MariaDB中多个坐标的多边形:

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,50.4668 -6.90665))'))

上面的查询结果是15.546039738650009,这是错误的.我使用this工具计算了多边形的面积,得出119116192747.1.

如何使mariaDB理解此多边形包含经度纬度以正确计算面积?

最佳答案根据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,50.4668 -6.90665))',4326));
总结

以上是内存溢出为你收集整理的mysql-ST_Area()用于纬度和经度 全部内容,希望文章能够帮你解决mysql-ST_Area()用于纬度和经度 所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1166003.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存