关于地理空间数据,常常须要处理两个空间数据的关联关系。有不少种方法能够处理,经过编写程序算法,或者是调用数据库中对应的function。在mysql数据库中,https://dev.mysql.com/doc/refman/5.1/en/functions-for-testing-spatial-relations-between-geometric-objects.html作了详细的介绍,可是它没有以具体的工程实践为例,本文以判断一个点是否落在多边形内的主题,加以简单的扩展。html
首先,创建一张简单的地理数据表mysql
CREATE TABLE `ci_special_zone` ( `id` int(11) NOT NULL auto_increment, `ploygongeo` text NOT NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
并插入几条数据算法
INSERT INTO ci_special_zone (ploygongeo) VALUES('POLYGON((113.547 22.186,113.549 22.186,113.549 22.188, 113.547 22.188,113.547 22.186))'); INSERT INTO ci_special_zone (ploygongeo) VALUES('POLYGON((112.547 21.186,112.549 212.186,112.549 21.188, 112.547 212.188,112.547 21.186))');
最后,执行以下的sql语句sql
SELECT substring(ploygongeo,10,length(ploygongeo)-11) from ci_special_zone where MBRContains(PolygonFromText(ploygongeo),PolygonFromText('Point(113.547 22.186)'))>0 limit 0,1
坐标点113.547 22.186是经纬度,如有返回值,则表示坐标点落在所在的区间。mongodb
mongodb版的可参见:https://blog.csdn.net/fdipzone/article/details/52374630数据库
原文连接:https://www.2cto.com/database/201211/166782.htmlspa