由于工作的业务于地图有关系,所以会经常出现,地图上画圆、画多边形,然后求在该区域内的一些业务数据;
计算时根据使用场景我一般使用一下方式:
一 、java程序内判断
优点:这种方式网上代码比较多,直接拿来就可以用。
缺点:当业务数据量比较大的时候,业务数据从仓库中取出在判断 ,资源消耗比较大,且通用性不是很好,不推荐;
二、将相关逻辑代码写成自定义数据库函数进行判断
优点:通用函数,可以直接在SQL上使用,使用方便;直接交由数据库处理,速度相对外部程序判断效率高;
缺点:对数据库服务器有压力
实现逻辑
第一种网上找就不说了;
第二种画圆的比较简单也不说了;
第三种多边形判断:(数据库是11g)
将前端画多边形的点位信息 拼成有规则的字符串 points = “map_x|map_y,map_x|map_y " (不能直接传数组进去)
传入自定义函数 F1(mapx,mapy,points) 中 ,函数根据传入的字符串按照规则 进行分割解析,得到成对的经纬度数组,
然后根据多边形点位判断逻辑判断是否在多边形内,返回结果值。
逻辑判断我是直接按java判断多边形点位关系的逻辑写的,经过测试可以正常判断。