首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > Mysql >

Mysql中判断一个点是不是落在多边形内

2012-11-11 
Mysql中判断一个点是否落在多边形内。关于地理空间数据,经常需要处理两个空间数据的关联关系。有很多种方法

Mysql中判断一个点是否落在多边形内。

        关于地理空间数据,经常需要处理两个空间数据的关联关系。有很多种方法可以处理,通过编写程序算法,或者是调用数据库中对应的function。在mysql数据库中,http://dev.mysql.com/doc/refman/5.1/en/functions-for-testing-spatial-relations-between-geometric-objects.html做了详细的介绍,但是它并没有真正的实现多边形(5.6版本之前),本文以判断一个点是否落在多边形内的主题,加以简单的扩展。


      首先,建立一张简单的地理数据表,


SELECT substring(ploygongeo,10,length(ploygongeo)-11) from ci_special_zone where myWithin(PolygonFromText('Point(113.547 22.186)'),PolygonFromText(ploygongeo))>0 limit 0,1

坐标点113.547 22.186是经纬度,若有返回值,则表示坐标点落在所在的区间。


热点排行