我有一个包括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));
(编辑:湖南网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|